home *** CD-ROM | disk | FTP | other *** search
/ PC World Komputer 2010 April / PCWorld0410.iso / hity wydania / Ubuntu 9.10 PL / karmelkowy-koliberek-desktop-9.10-i386-PL.iso / casper / filesystem.squashfs / usr / share / pyshared / xapian.py < prev    next >
Text File  |  2009-10-22  |  202KB  |  5,292 lines

  1. # This file was automatically generated by SWIG (http://www.swig.org).
  2. # Version 1.3.32
  3. #
  4. # Don't modify this file, modify the SWIG interface instead.
  5.  
  6. import _xapian
  7. import new
  8. new_instancemethod = new.instancemethod
  9. try:
  10.     _swig_property = property
  11. except NameError:
  12.     pass # Python < 2.2 doesn't have 'property'.
  13. def _swig_setattr_nondynamic(self,class_type,name,value,static=1):
  14.     if (name == "thisown"): return self.this.own(value)
  15.     if (name == "this"):
  16.         if type(value).__name__ == 'PySwigObject':
  17.             self.__dict__[name] = value
  18.             return
  19.     method = class_type.__swig_setmethods__.get(name,None)
  20.     if method: return method(self,value)
  21.     if (not static) or hasattr(self,name):
  22.         self.__dict__[name] = value
  23.     else:
  24.         raise AttributeError("You cannot add attributes to %s" % self)
  25.  
  26. def _swig_setattr(self,class_type,name,value):
  27.     return _swig_setattr_nondynamic(self,class_type,name,value,0)
  28.  
  29. def _swig_getattr(self,class_type,name):
  30.     if (name == "thisown"): return self.this.own()
  31.     method = class_type.__swig_getmethods__.get(name,None)
  32.     if method: return method(self)
  33.     raise AttributeError,name
  34.  
  35. def _swig_repr(self):
  36.     try: strthis = "proxy of " + self.this.__repr__()
  37.     except: strthis = ""
  38.     return "<%s.%s; %s >" % (self.__class__.__module__, self.__class__.__name__, strthis,)
  39.  
  40. import types
  41. try:
  42.     _object = types.ObjectType
  43.     _newclass = 1
  44. except AttributeError:
  45.     class _object : pass
  46.     _newclass = 0
  47. del types
  48.  
  49.  
  50. def _swig_setattr_nondynamic_method(set):
  51.     def set_attr(self,name,value):
  52.         if (name == "thisown"): return self.this.own(value)
  53.         if hasattr(self,name) or (name == "this"):
  54.             set(self,name,value)
  55.         else:
  56.             raise AttributeError("You cannot add attributes to %s" % self)
  57.     return set_attr
  58.  
  59.  
  60. try:
  61.     import weakref
  62.     weakref_proxy = weakref.proxy
  63. except:
  64.     weakref_proxy = lambda x: x
  65.  
  66.  
  67. class PySwigIterator(object):
  68.     thisown = _swig_property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc='The membership flag')
  69.     def __init__(self): raise AttributeError, "No constructor defined"
  70.     __repr__ = _swig_repr
  71.     __swig_destroy__ = _xapian.delete_PySwigIterator
  72.     def __iter__(self): return self
  73. PySwigIterator.value = new_instancemethod(_xapian.PySwigIterator_value,None,PySwigIterator)
  74. PySwigIterator.incr = new_instancemethod(_xapian.PySwigIterator_incr,None,PySwigIterator)
  75. PySwigIterator.decr = new_instancemethod(_xapian.PySwigIterator_decr,None,PySwigIterator)
  76. PySwigIterator.distance = new_instancemethod(_xapian.PySwigIterator_distance,None,PySwigIterator)
  77. PySwigIterator.equal = new_instancemethod(_xapian.PySwigIterator_equal,None,PySwigIterator)
  78. PySwigIterator.copy = new_instancemethod(_xapian.PySwigIterator_copy,None,PySwigIterator)
  79. PySwigIterator.next = new_instancemethod(_xapian.PySwigIterator_next,None,PySwigIterator)
  80. PySwigIterator.previous = new_instancemethod(_xapian.PySwigIterator_previous,None,PySwigIterator)
  81. PySwigIterator.advance = new_instancemethod(_xapian.PySwigIterator_advance,None,PySwigIterator)
  82. PySwigIterator.__eq__ = new_instancemethod(_xapian.PySwigIterator___eq__,None,PySwigIterator)
  83. PySwigIterator.__ne__ = new_instancemethod(_xapian.PySwigIterator___ne__,None,PySwigIterator)
  84. PySwigIterator.__iadd__ = new_instancemethod(_xapian.PySwigIterator___iadd__,None,PySwigIterator)
  85. PySwigIterator.__isub__ = new_instancemethod(_xapian.PySwigIterator___isub__,None,PySwigIterator)
  86. PySwigIterator.__add__ = new_instancemethod(_xapian.PySwigIterator___add__,None,PySwigIterator)
  87. PySwigIterator.__sub__ = new_instancemethod(_xapian.PySwigIterator___sub__,None,PySwigIterator)
  88. PySwigIterator_swigregister = _xapian.PySwigIterator_swigregister
  89. PySwigIterator_swigregister(PySwigIterator)
  90.  
  91. MSET_DID = _xapian.MSET_DID
  92. MSET_WT = _xapian.MSET_WT
  93. MSET_RANK = _xapian.MSET_RANK
  94. MSET_PERCENT = _xapian.MSET_PERCENT
  95. MSET_DOCUMENT = _xapian.MSET_DOCUMENT
  96. ESET_TNAME = _xapian.ESET_TNAME
  97. ESET_WT = _xapian.ESET_WT
  98. class Error(Exception):
  99.     __swig_setmethods__ = {}
  100.     __setattr__ = lambda self, name, value: _swig_setattr(self, Error, name, value)
  101.     __swig_getmethods__ = {}
  102.     __getattr__ = lambda self, name: _swig_getattr(self, Error, name)
  103.     def __init__(self): raise AttributeError, "No constructor defined"
  104.     __repr__ = _swig_repr
  105.     __swig_destroy__ = _xapian.delete_Error
  106. Error.get_type = new_instancemethod(_xapian.Error_get_type,None,Error)
  107. Error.get_msg = new_instancemethod(_xapian.Error_get_msg,None,Error)
  108. Error.get_context = new_instancemethod(_xapian.Error_get_context,None,Error)
  109. Error.get_error_string = new_instancemethod(_xapian.Error_get_error_string,None,Error)
  110. Error.get_errno = new_instancemethod(_xapian.Error_get_errno,None,Error)
  111. Error.__str__ = new_instancemethod(_xapian.Error___str__,None,Error)
  112. Error_swigregister = _xapian.Error_swigregister
  113. Error_swigregister(Error)
  114.  
  115. class LogicError(Error):
  116.     __swig_setmethods__ = {}
  117.     for _s in [Error]: __swig_setmethods__.update(getattr(_s,'__swig_setmethods__',{}))
  118.     __setattr__ = lambda self, name, value: _swig_setattr(self, LogicError, name, value)
  119.     __swig_getmethods__ = {}
  120.     for _s in [Error]: __swig_getmethods__.update(getattr(_s,'__swig_getmethods__',{}))
  121.     __getattr__ = lambda self, name: _swig_getattr(self, LogicError, name)
  122.     def __init__(self): raise AttributeError, "No constructor defined"
  123.     __repr__ = _swig_repr
  124.     __swig_destroy__ = _xapian.delete_LogicError
  125. LogicError_swigregister = _xapian.LogicError_swigregister
  126. LogicError_swigregister(LogicError)
  127.  
  128. class RuntimeError(Error):
  129.     __swig_setmethods__ = {}
  130.     for _s in [Error]: __swig_setmethods__.update(getattr(_s,'__swig_setmethods__',{}))
  131.     __setattr__ = lambda self, name, value: _swig_setattr(self, RuntimeError, name, value)
  132.     __swig_getmethods__ = {}
  133.     for _s in [Error]: __swig_getmethods__.update(getattr(_s,'__swig_getmethods__',{}))
  134.     __getattr__ = lambda self, name: _swig_getattr(self, RuntimeError, name)
  135.     def __init__(self): raise AttributeError, "No constructor defined"
  136.     __repr__ = _swig_repr
  137.     __swig_destroy__ = _xapian.delete_RuntimeError
  138. RuntimeError_swigregister = _xapian.RuntimeError_swigregister
  139. RuntimeError_swigregister(RuntimeError)
  140.  
  141. class AssertionError(LogicError):
  142.     __swig_setmethods__ = {}
  143.     for _s in [LogicError]: __swig_setmethods__.update(getattr(_s,'__swig_setmethods__',{}))
  144.     __setattr__ = lambda self, name, value: _swig_setattr(self, AssertionError, name, value)
  145.     __swig_getmethods__ = {}
  146.     for _s in [LogicError]: __swig_getmethods__.update(getattr(_s,'__swig_getmethods__',{}))
  147.     __getattr__ = lambda self, name: _swig_getattr(self, AssertionError, name)
  148.     __repr__ = _swig_repr
  149.     def __init__(self, *args): 
  150.         _xapian.AssertionError_swiginit(self,_xapian.new_AssertionError(*args))
  151.     __swig_destroy__ = _xapian.delete_AssertionError
  152. AssertionError_swigregister = _xapian.AssertionError_swigregister
  153. AssertionError_swigregister(AssertionError)
  154.  
  155. class InvalidArgumentError(LogicError):
  156.     __swig_setmethods__ = {}
  157.     for _s in [LogicError]: __swig_setmethods__.update(getattr(_s,'__swig_setmethods__',{}))
  158.     __setattr__ = lambda self, name, value: _swig_setattr(self, InvalidArgumentError, name, value)
  159.     __swig_getmethods__ = {}
  160.     for _s in [LogicError]: __swig_getmethods__.update(getattr(_s,'__swig_getmethods__',{}))
  161.     __getattr__ = lambda self, name: _swig_getattr(self, InvalidArgumentError, name)
  162.     __repr__ = _swig_repr
  163.     def __init__(self, *args): 
  164.         _xapian.InvalidArgumentError_swiginit(self,_xapian.new_InvalidArgumentError(*args))
  165.     __swig_destroy__ = _xapian.delete_InvalidArgumentError
  166. InvalidArgumentError_swigregister = _xapian.InvalidArgumentError_swigregister
  167. InvalidArgumentError_swigregister(InvalidArgumentError)
  168.  
  169. class InvalidOperationError(LogicError):
  170.     __swig_setmethods__ = {}
  171.     for _s in [LogicError]: __swig_setmethods__.update(getattr(_s,'__swig_setmethods__',{}))
  172.     __setattr__ = lambda self, name, value: _swig_setattr(self, InvalidOperationError, name, value)
  173.     __swig_getmethods__ = {}
  174.     for _s in [LogicError]: __swig_getmethods__.update(getattr(_s,'__swig_getmethods__',{}))
  175.     __getattr__ = lambda self, name: _swig_getattr(self, InvalidOperationError, name)
  176.     __repr__ = _swig_repr
  177.     def __init__(self, *args): 
  178.         _xapian.InvalidOperationError_swiginit(self,_xapian.new_InvalidOperationError(*args))
  179.     __swig_destroy__ = _xapian.delete_InvalidOperationError
  180. InvalidOperationError_swigregister = _xapian.InvalidOperationError_swigregister
  181. InvalidOperationError_swigregister(InvalidOperationError)
  182.  
  183. class UnimplementedError(LogicError):
  184.     __swig_setmethods__ = {}
  185.     for _s in [LogicError]: __swig_setmethods__.update(getattr(_s,'__swig_setmethods__',{}))
  186.     __setattr__ = lambda self, name, value: _swig_setattr(self, UnimplementedError, name, value)
  187.     __swig_getmethods__ = {}
  188.     for _s in [LogicError]: __swig_getmethods__.update(getattr(_s,'__swig_getmethods__',{}))
  189.     __getattr__ = lambda self, name: _swig_getattr(self, UnimplementedError, name)
  190.     __repr__ = _swig_repr
  191.     def __init__(self, *args): 
  192.         _xapian.UnimplementedError_swiginit(self,_xapian.new_UnimplementedError(*args))
  193.     __swig_destroy__ = _xapian.delete_UnimplementedError
  194. UnimplementedError_swigregister = _xapian.UnimplementedError_swigregister
  195. UnimplementedError_swigregister(UnimplementedError)
  196.  
  197. class DatabaseError(RuntimeError):
  198.     __swig_setmethods__ = {}
  199.     for _s in [RuntimeError]: __swig_setmethods__.update(getattr(_s,'__swig_setmethods__',{}))
  200.     __setattr__ = lambda self, name, value: _swig_setattr(self, DatabaseError, name, value)
  201.     __swig_getmethods__ = {}
  202.     for _s in [RuntimeError]: __swig_getmethods__.update(getattr(_s,'__swig_getmethods__',{}))
  203.     __getattr__ = lambda self, name: _swig_getattr(self, DatabaseError, name)
  204.     __repr__ = _swig_repr
  205.     def __init__(self, *args): 
  206.         _xapian.DatabaseError_swiginit(self,_xapian.new_DatabaseError(*args))
  207.     __swig_destroy__ = _xapian.delete_DatabaseError
  208. DatabaseError_swigregister = _xapian.DatabaseError_swigregister
  209. DatabaseError_swigregister(DatabaseError)
  210.  
  211. class DatabaseCorruptError(DatabaseError):
  212.     __swig_setmethods__ = {}
  213.     for _s in [DatabaseError]: __swig_setmethods__.update(getattr(_s,'__swig_setmethods__',{}))
  214.     __setattr__ = lambda self, name, value: _swig_setattr(self, DatabaseCorruptError, name, value)
  215.     __swig_getmethods__ = {}
  216.     for _s in [DatabaseError]: __swig_getmethods__.update(getattr(_s,'__swig_getmethods__',{}))
  217.     __getattr__ = lambda self, name: _swig_getattr(self, DatabaseCorruptError, name)
  218.     __repr__ = _swig_repr
  219.     def __init__(self, *args): 
  220.         _xapian.DatabaseCorruptError_swiginit(self,_xapian.new_DatabaseCorruptError(*args))
  221.     __swig_destroy__ = _xapian.delete_DatabaseCorruptError
  222. DatabaseCorruptError_swigregister = _xapian.DatabaseCorruptError_swigregister
  223. DatabaseCorruptError_swigregister(DatabaseCorruptError)
  224.  
  225. class DatabaseCreateError(DatabaseError):
  226.     __swig_setmethods__ = {}
  227.     for _s in [DatabaseError]: __swig_setmethods__.update(getattr(_s,'__swig_setmethods__',{}))
  228.     __setattr__ = lambda self, name, value: _swig_setattr(self, DatabaseCreateError, name, value)
  229.     __swig_getmethods__ = {}
  230.     for _s in [DatabaseError]: __swig_getmethods__.update(getattr(_s,'__swig_getmethods__',{}))
  231.     __getattr__ = lambda self, name: _swig_getattr(self, DatabaseCreateError, name)
  232.     __repr__ = _swig_repr
  233.     def __init__(self, *args): 
  234.         _xapian.DatabaseCreateError_swiginit(self,_xapian.new_DatabaseCreateError(*args))
  235.     __swig_destroy__ = _xapian.delete_DatabaseCreateError
  236. DatabaseCreateError_swigregister = _xapian.DatabaseCreateError_swigregister
  237. DatabaseCreateError_swigregister(DatabaseCreateError)
  238.  
  239. class DatabaseLockError(DatabaseError):
  240.     __swig_setmethods__ = {}
  241.     for _s in [DatabaseError]: __swig_setmethods__.update(getattr(_s,'__swig_setmethods__',{}))
  242.     __setattr__ = lambda self, name, value: _swig_setattr(self, DatabaseLockError, name, value)
  243.     __swig_getmethods__ = {}
  244.     for _s in [DatabaseError]: __swig_getmethods__.update(getattr(_s,'__swig_getmethods__',{}))
  245.     __getattr__ = lambda self, name: _swig_getattr(self, DatabaseLockError, name)
  246.     __repr__ = _swig_repr
  247.     def __init__(self, *args): 
  248.         _xapian.DatabaseLockError_swiginit(self,_xapian.new_DatabaseLockError(*args))
  249.     __swig_destroy__ = _xapian.delete_DatabaseLockError
  250. DatabaseLockError_swigregister = _xapian.DatabaseLockError_swigregister
  251. DatabaseLockError_swigregister(DatabaseLockError)
  252.  
  253. class DatabaseModifiedError(DatabaseError):
  254.     __swig_setmethods__ = {}
  255.     for _s in [DatabaseError]: __swig_setmethods__.update(getattr(_s,'__swig_setmethods__',{}))
  256.     __setattr__ = lambda self, name, value: _swig_setattr(self, DatabaseModifiedError, name, value)
  257.     __swig_getmethods__ = {}
  258.     for _s in [DatabaseError]: __swig_getmethods__.update(getattr(_s,'__swig_getmethods__',{}))
  259.     __getattr__ = lambda self, name: _swig_getattr(self, DatabaseModifiedError, name)
  260.     __repr__ = _swig_repr
  261.     def __init__(self, *args): 
  262.         _xapian.DatabaseModifiedError_swiginit(self,_xapian.new_DatabaseModifiedError(*args))
  263.     __swig_destroy__ = _xapian.delete_DatabaseModifiedError
  264. DatabaseModifiedError_swigregister = _xapian.DatabaseModifiedError_swigregister
  265. DatabaseModifiedError_swigregister(DatabaseModifiedError)
  266.  
  267. class DatabaseOpeningError(DatabaseError):
  268.     __swig_setmethods__ = {}
  269.     for _s in [DatabaseError]: __swig_setmethods__.update(getattr(_s,'__swig_setmethods__',{}))
  270.     __setattr__ = lambda self, name, value: _swig_setattr(self, DatabaseOpeningError, name, value)
  271.     __swig_getmethods__ = {}
  272.     for _s in [DatabaseError]: __swig_getmethods__.update(getattr(_s,'__swig_getmethods__',{}))
  273.     __getattr__ = lambda self, name: _swig_getattr(self, DatabaseOpeningError, name)
  274.     __repr__ = _swig_repr
  275.     def __init__(self, *args): 
  276.         _xapian.DatabaseOpeningError_swiginit(self,_xapian.new_DatabaseOpeningError(*args))
  277.     __swig_destroy__ = _xapian.delete_DatabaseOpeningError
  278. DatabaseOpeningError_swigregister = _xapian.DatabaseOpeningError_swigregister
  279. DatabaseOpeningError_swigregister(DatabaseOpeningError)
  280.  
  281. class DatabaseVersionError(DatabaseOpeningError):
  282.     __swig_setmethods__ = {}
  283.     for _s in [DatabaseOpeningError]: __swig_setmethods__.update(getattr(_s,'__swig_setmethods__',{}))
  284.     __setattr__ = lambda self, name, value: _swig_setattr(self, DatabaseVersionError, name, value)
  285.     __swig_getmethods__ = {}
  286.     for _s in [DatabaseOpeningError]: __swig_getmethods__.update(getattr(_s,'__swig_getmethods__',{}))
  287.     __getattr__ = lambda self, name: _swig_getattr(self, DatabaseVersionError, name)
  288.     __repr__ = _swig_repr
  289.     def __init__(self, *args): 
  290.         _xapian.DatabaseVersionError_swiginit(self,_xapian.new_DatabaseVersionError(*args))
  291.     __swig_destroy__ = _xapian.delete_DatabaseVersionError
  292. DatabaseVersionError_swigregister = _xapian.DatabaseVersionError_swigregister
  293. DatabaseVersionError_swigregister(DatabaseVersionError)
  294.  
  295. class DocNotFoundError(RuntimeError):
  296.     __swig_setmethods__ = {}
  297.     for _s in [RuntimeError]: __swig_setmethods__.update(getattr(_s,'__swig_setmethods__',{}))
  298.     __setattr__ = lambda self, name, value: _swig_setattr(self, DocNotFoundError, name, value)
  299.     __swig_getmethods__ = {}
  300.     for _s in [RuntimeError]: __swig_getmethods__.update(getattr(_s,'__swig_getmethods__',{}))
  301.     __getattr__ = lambda self, name: _swig_getattr(self, DocNotFoundError, name)
  302.     __repr__ = _swig_repr
  303.     def __init__(self, *args): 
  304.         _xapian.DocNotFoundError_swiginit(self,_xapian.new_DocNotFoundError(*args))
  305.     __swig_destroy__ = _xapian.delete_DocNotFoundError
  306. DocNotFoundError_swigregister = _xapian.DocNotFoundError_swigregister
  307. DocNotFoundError_swigregister(DocNotFoundError)
  308.  
  309. class FeatureUnavailableError(RuntimeError):
  310.     __swig_setmethods__ = {}
  311.     for _s in [RuntimeError]: __swig_setmethods__.update(getattr(_s,'__swig_setmethods__',{}))
  312.     __setattr__ = lambda self, name, value: _swig_setattr(self, FeatureUnavailableError, name, value)
  313.     __swig_getmethods__ = {}
  314.     for _s in [RuntimeError]: __swig_getmethods__.update(getattr(_s,'__swig_getmethods__',{}))
  315.     __getattr__ = lambda self, name: _swig_getattr(self, FeatureUnavailableError, name)
  316.     __repr__ = _swig_repr
  317.     def __init__(self, *args): 
  318.         _xapian.FeatureUnavailableError_swiginit(self,_xapian.new_FeatureUnavailableError(*args))
  319.     __swig_destroy__ = _xapian.delete_FeatureUnavailableError
  320. FeatureUnavailableError_swigregister = _xapian.FeatureUnavailableError_swigregister
  321. FeatureUnavailableError_swigregister(FeatureUnavailableError)
  322.  
  323. class InternalError(RuntimeError):
  324.     __swig_setmethods__ = {}
  325.     for _s in [RuntimeError]: __swig_setmethods__.update(getattr(_s,'__swig_setmethods__',{}))
  326.     __setattr__ = lambda self, name, value: _swig_setattr(self, InternalError, name, value)
  327.     __swig_getmethods__ = {}
  328.     for _s in [RuntimeError]: __swig_getmethods__.update(getattr(_s,'__swig_getmethods__',{}))
  329.     __getattr__ = lambda self, name: _swig_getattr(self, InternalError, name)
  330.     __repr__ = _swig_repr
  331.     def __init__(self, *args): 
  332.         _xapian.InternalError_swiginit(self,_xapian.new_InternalError(*args))
  333.     __swig_destroy__ = _xapian.delete_InternalError
  334. InternalError_swigregister = _xapian.InternalError_swigregister
  335. InternalError_swigregister(InternalError)
  336.  
  337. class NetworkError(RuntimeError):
  338.     __swig_setmethods__ = {}
  339.     for _s in [RuntimeError]: __swig_setmethods__.update(getattr(_s,'__swig_setmethods__',{}))
  340.     __setattr__ = lambda self, name, value: _swig_setattr(self, NetworkError, name, value)
  341.     __swig_getmethods__ = {}
  342.     for _s in [RuntimeError]: __swig_getmethods__.update(getattr(_s,'__swig_getmethods__',{}))
  343.     __getattr__ = lambda self, name: _swig_getattr(self, NetworkError, name)
  344.     __repr__ = _swig_repr
  345.     def __init__(self, *args): 
  346.         _xapian.NetworkError_swiginit(self,_xapian.new_NetworkError(*args))
  347.     __swig_destroy__ = _xapian.delete_NetworkError
  348. NetworkError_swigregister = _xapian.NetworkError_swigregister
  349. NetworkError_swigregister(NetworkError)
  350.  
  351. class NetworkTimeoutError(NetworkError):
  352.     __swig_setmethods__ = {}
  353.     for _s in [NetworkError]: __swig_setmethods__.update(getattr(_s,'__swig_setmethods__',{}))
  354.     __setattr__ = lambda self, name, value: _swig_setattr(self, NetworkTimeoutError, name, value)
  355.     __swig_getmethods__ = {}
  356.     for _s in [NetworkError]: __swig_getmethods__.update(getattr(_s,'__swig_getmethods__',{}))
  357.     __getattr__ = lambda self, name: _swig_getattr(self, NetworkTimeoutError, name)
  358.     __repr__ = _swig_repr
  359.     def __init__(self, *args): 
  360.         _xapian.NetworkTimeoutError_swiginit(self,_xapian.new_NetworkTimeoutError(*args))
  361.     __swig_destroy__ = _xapian.delete_NetworkTimeoutError
  362. NetworkTimeoutError_swigregister = _xapian.NetworkTimeoutError_swigregister
  363. NetworkTimeoutError_swigregister(NetworkTimeoutError)
  364.  
  365. class QueryParserError(RuntimeError):
  366.     __swig_setmethods__ = {}
  367.     for _s in [RuntimeError]: __swig_setmethods__.update(getattr(_s,'__swig_setmethods__',{}))
  368.     __setattr__ = lambda self, name, value: _swig_setattr(self, QueryParserError, name, value)
  369.     __swig_getmethods__ = {}
  370.     for _s in [RuntimeError]: __swig_getmethods__.update(getattr(_s,'__swig_getmethods__',{}))
  371.     __getattr__ = lambda self, name: _swig_getattr(self, QueryParserError, name)
  372.     __repr__ = _swig_repr
  373.     def __init__(self, *args): 
  374.         _xapian.QueryParserError_swiginit(self,_xapian.new_QueryParserError(*args))
  375.     __swig_destroy__ = _xapian.delete_QueryParserError
  376. QueryParserError_swigregister = _xapian.QueryParserError_swigregister
  377. QueryParserError_swigregister(QueryParserError)
  378.  
  379. class RangeError(RuntimeError):
  380.     __swig_setmethods__ = {}
  381.     for _s in [RuntimeError]: __swig_setmethods__.update(getattr(_s,'__swig_setmethods__',{}))
  382.     __setattr__ = lambda self, name, value: _swig_setattr(self, RangeError, name, value)
  383.     __swig_getmethods__ = {}
  384.     for _s in [RuntimeError]: __swig_getmethods__.update(getattr(_s,'__swig_getmethods__',{}))
  385.     __getattr__ = lambda self, name: _swig_getattr(self, RangeError, name)
  386.     __repr__ = _swig_repr
  387.     def __init__(self, *args): 
  388.         _xapian.RangeError_swiginit(self,_xapian.new_RangeError(*args))
  389.     __swig_destroy__ = _xapian.delete_RangeError
  390. RangeError_swigregister = _xapian.RangeError_swigregister
  391. RangeError_swigregister(RangeError)
  392.  
  393. version_string = _xapian.version_string
  394. major_version = _xapian.major_version
  395. minor_version = _xapian.minor_version
  396. revision = _xapian.revision
  397. xapian_version_string = _xapian.xapian_version_string
  398. xapian_major_version = _xapian.xapian_major_version
  399. xapian_minor_version = _xapian.xapian_minor_version
  400. xapian_revision = _xapian.xapian_revision
  401. class PositionIterator(object):
  402.     """
  403.     An iterator pointing to items in a list of positions. 
  404.     """
  405.     thisown = _swig_property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc='The membership flag')
  406.     __repr__ = _swig_repr
  407.     def __init__(self, *args): 
  408.         """
  409.         Copying is allowed.
  410.  
  411.         Xapian::PositionIterator::PositionIterator(const PositionIterator &o)
  412.  
  413.         The internals are reference counted, so copying is also cheap. 
  414.         """
  415.         _xapian.PositionIterator_swiginit(self,_xapian.new_PositionIterator(*args))
  416.     __swig_destroy__ = _xapian.delete_PositionIterator
  417.     def skip_to(*args):
  418.         """
  419.         void
  420.         Xapian::PositionIterator::skip_to(Xapian::termpos pos) 
  421.         """
  422.         return _xapian.PositionIterator_skip_to(*args)
  423.  
  424.     def __str__(*args):
  425.         """
  426.         Return a string describing this object.
  427.  
  428.         std::string Xapian::PositionIterator::get_description() const 
  429.         """
  430.         return _xapian.PositionIterator___str__(*args)
  431.  
  432.     def get_description(*args):
  433.         """
  434.         Return a string describing this object.
  435.  
  436.         std::string Xapian::PositionIterator::get_description() const 
  437.         """
  438.         return _xapian.PositionIterator_get_description(*args)
  439.  
  440. PositionIterator.get_termpos = new_instancemethod(_xapian.PositionIterator_get_termpos,None,PositionIterator)
  441. PositionIterator.next = new_instancemethod(_xapian.PositionIterator_next,None,PositionIterator)
  442. PositionIterator.equals = new_instancemethod(_xapian.PositionIterator_equals,None,PositionIterator)
  443. PositionIterator.skip_to = new_instancemethod(_xapian.PositionIterator_skip_to,None,PositionIterator)
  444. PositionIterator.__str__ = new_instancemethod(_xapian.PositionIterator___str__,None,PositionIterator)
  445. PositionIterator.get_description = new_instancemethod(_xapian.PositionIterator_get_description,None,PositionIterator)
  446. PositionIterator.__eq__ = new_instancemethod(_xapian.PositionIterator___eq__,None,PositionIterator)
  447. PositionIterator.__ne__ = new_instancemethod(_xapian.PositionIterator___ne__,None,PositionIterator)
  448. PositionIterator_swigregister = _xapian.PositionIterator_swigregister
  449. PositionIterator_swigregister(PositionIterator)
  450. cvar = _xapian.cvar
  451. BAD_VALUENO = cvar.BAD_VALUENO
  452.  
  453. class PostingIterator(object):
  454.     """
  455.     An iterator pointing to items in a list of postings. 
  456.     """
  457.     thisown = _swig_property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc='The membership flag')
  458.     __repr__ = _swig_repr
  459.     __swig_destroy__ = _xapian.delete_PostingIterator
  460.     def __init__(self, *args): 
  461.         """
  462.         Copying is allowed.
  463.  
  464.         Xapian::PostingIterator::PostingIterator(const PostingIterator &other)
  465.  
  466.         The internals are reference counted, so copying is also cheap. 
  467.         """
  468.         _xapian.PostingIterator_swiginit(self,_xapian.new_PostingIterator(*args))
  469.     def skip_to(*args):
  470.         """
  471.         Skip the iterator to document did, or the first document after did if
  472.         did isn't in the list of documents being iterated.
  473.  
  474.         void Xapian::PostingIterator::skip_to(Xapian::docid did) 
  475.         """
  476.         return _xapian.PostingIterator_skip_to(*args)
  477.  
  478.     def get_doclength(*args):
  479.         """
  480.         Get the length of the document at the current position in the
  481.         postlist.
  482.  
  483.         Xapian::doclength Xapian::PostingIterator::get_doclength() const
  484.  
  485.         This information may be stored in the postlist, in which case this
  486.         lookup should be extremely fast (indeed, not require further disk
  487.         access). If the information is not present in the postlist, it will be
  488.         retrieved from the database, at a greater performance cost. 
  489.         """
  490.         return _xapian.PostingIterator_get_doclength(*args)
  491.  
  492.     def get_wdf(*args):
  493.         """
  494.         Get the within document frequency of the document at the current
  495.         position in the postlist.
  496.  
  497.         Xapian::termcount Xapian::PostingIterator::get_wdf() const 
  498.         """
  499.         return _xapian.PostingIterator_get_wdf(*args)
  500.  
  501.     def positionlist_begin(*args):
  502.         """
  503.         Return PositionIterator pointing to start of positionlist for current
  504.         document.
  505.  
  506.         PositionIterator Xapian::PostingIterator::positionlist_begin() const
  507.  
  508.         """
  509.         return _xapian.PostingIterator_positionlist_begin(*args)
  510.  
  511.     def positionlist_end(*args):
  512.         """
  513.         Return PositionIterator pointing to end of positionlist for current
  514.         document.
  515.  
  516.         PositionIterator Xapian::PostingIterator::positionlist_end() const 
  517.         """
  518.         return _xapian.PostingIterator_positionlist_end(*args)
  519.  
  520.     def __str__(*args):
  521.         """
  522.         Return a string describing this object.
  523.  
  524.         std::string Xapian::PostingIterator::get_description() const 
  525.         """
  526.         return _xapian.PostingIterator___str__(*args)
  527.  
  528.     def get_description(*args):
  529.         """
  530.         Return a string describing this object.
  531.  
  532.         std::string Xapian::PostingIterator::get_description() const 
  533.         """
  534.         return _xapian.PostingIterator_get_description(*args)
  535.  
  536. PostingIterator.skip_to = new_instancemethod(_xapian.PostingIterator_skip_to,None,PostingIterator)
  537. PostingIterator.get_doclength = new_instancemethod(_xapian.PostingIterator_get_doclength,None,PostingIterator)
  538. PostingIterator.get_wdf = new_instancemethod(_xapian.PostingIterator_get_wdf,None,PostingIterator)
  539. PostingIterator.positionlist_begin = new_instancemethod(_xapian.PostingIterator_positionlist_begin,None,PostingIterator)
  540. PostingIterator.positionlist_end = new_instancemethod(_xapian.PostingIterator_positionlist_end,None,PostingIterator)
  541. PostingIterator.__str__ = new_instancemethod(_xapian.PostingIterator___str__,None,PostingIterator)
  542. PostingIterator.get_description = new_instancemethod(_xapian.PostingIterator_get_description,None,PostingIterator)
  543. PostingIterator.__eq__ = new_instancemethod(_xapian.PostingIterator___eq__,None,PostingIterator)
  544. PostingIterator.__ne__ = new_instancemethod(_xapian.PostingIterator___ne__,None,PostingIterator)
  545. PostingIterator.get_docid = new_instancemethod(_xapian.PostingIterator_get_docid,None,PostingIterator)
  546. PostingIterator.next = new_instancemethod(_xapian.PostingIterator_next,None,PostingIterator)
  547. PostingIterator.equals = new_instancemethod(_xapian.PostingIterator_equals,None,PostingIterator)
  548. PostingIterator_swigregister = _xapian.PostingIterator_swigregister
  549. PostingIterator_swigregister(PostingIterator)
  550.  
  551. __eq__ = _xapian.__eq__
  552. __ne__ = _xapian.__ne__
  553. class TermIterator(object):
  554.     """
  555.     An iterator pointing to items in a list of terms. 
  556.     """
  557.     thisown = _swig_property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc='The membership flag')
  558.     __repr__ = _swig_repr
  559.     def __init__(self, *args): 
  560.         """
  561.         Copying is allowed.
  562.  
  563.         Xapian::TermIterator::TermIterator(const TermIterator &other)
  564.  
  565.         The internals are reference counted, so copying is also cheap. 
  566.         """
  567.         _xapian.TermIterator_swiginit(self,_xapian.new_TermIterator(*args))
  568.     __swig_destroy__ = _xapian.delete_TermIterator
  569.     def skip_to(*args):
  570.         """
  571.         Skip the iterator to term tname, or the first term after tname if
  572.         tname isn't in the list of terms being iterated.
  573.  
  574.         void Xapian::TermIterator::skip_to(const std::string &tname) 
  575.         """
  576.         return _xapian.TermIterator_skip_to(*args)
  577.  
  578.     def get_wdf(*args):
  579.         """
  580.         Return the wdf of the current term (if meaningful).
  581.  
  582.         Xapian::termcount Xapian::TermIterator::get_wdf() const
  583.  
  584.         The wdf (within document frequency) is the number of occurences of a
  585.         term in a particular document. 
  586.         """
  587.         return _xapian.TermIterator_get_wdf(*args)
  588.  
  589.     def get_termfreq(*args):
  590.         """
  591.         Return the term frequency of the current term (if meaningful).
  592.  
  593.         Xapian::doccount Xapian::TermIterator::get_termfreq() const
  594.  
  595.         The term frequency is the number of documents which a term indexes. 
  596.         """
  597.         return _xapian.TermIterator_get_termfreq(*args)
  598.  
  599.     def positionlist_begin(*args):
  600.         """
  601.         Return PositionIterator pointing to start of positionlist for current
  602.         term.
  603.  
  604.         PositionIterator Xapian::TermIterator::positionlist_begin() const 
  605.         """
  606.         return _xapian.TermIterator_positionlist_begin(*args)
  607.  
  608.     def positionlist_end(*args):
  609.         """
  610.         Return PositionIterator pointing to end of positionlist for current
  611.         term.
  612.  
  613.         PositionIterator Xapian::TermIterator::positionlist_end() const 
  614.         """
  615.         return _xapian.TermIterator_positionlist_end(*args)
  616.  
  617.     def __str__(*args):
  618.         """
  619.         Return a string describing this object.
  620.  
  621.         std::string Xapian::TermIterator::get_description() const 
  622.         """
  623.         return _xapian.TermIterator___str__(*args)
  624.  
  625.     def get_description(*args):
  626.         """
  627.         Return a string describing this object.
  628.  
  629.         std::string Xapian::TermIterator::get_description() const 
  630.         """
  631.         return _xapian.TermIterator_get_description(*args)
  632.  
  633. TermIterator.get_term = new_instancemethod(_xapian.TermIterator_get_term,None,TermIterator)
  634. TermIterator.next = new_instancemethod(_xapian.TermIterator_next,None,TermIterator)
  635. TermIterator.equals = new_instancemethod(_xapian.TermIterator_equals,None,TermIterator)
  636. TermIterator.skip_to = new_instancemethod(_xapian.TermIterator_skip_to,None,TermIterator)
  637. TermIterator.get_wdf = new_instancemethod(_xapian.TermIterator_get_wdf,None,TermIterator)
  638. TermIterator.get_termfreq = new_instancemethod(_xapian.TermIterator_get_termfreq,None,TermIterator)
  639. TermIterator.positionlist_begin = new_instancemethod(_xapian.TermIterator_positionlist_begin,None,TermIterator)
  640. TermIterator.positionlist_end = new_instancemethod(_xapian.TermIterator_positionlist_end,None,TermIterator)
  641. TermIterator.__str__ = new_instancemethod(_xapian.TermIterator___str__,None,TermIterator)
  642. TermIterator.get_description = new_instancemethod(_xapian.TermIterator_get_description,None,TermIterator)
  643. TermIterator.__eq__ = new_instancemethod(_xapian.TermIterator___eq__,None,TermIterator)
  644. TermIterator.__ne__ = new_instancemethod(_xapian.TermIterator___ne__,None,TermIterator)
  645. TermIterator_swigregister = _xapian.TermIterator_swigregister
  646. TermIterator_swigregister(TermIterator)
  647.  
  648. class ValueIterator(object):
  649.     """
  650.     An iterator pointing to values associated with a document. 
  651.     """
  652.     thisown = _swig_property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc='The membership flag')
  653.     __repr__ = _swig_repr
  654.     def __init__(self, *args): 
  655.         """
  656.         Copying is allowed (and is cheap).
  657.  
  658.         Xapian::ValueIterator::ValueIterator(const ValueIterator &other) 
  659.         """
  660.         _xapian.ValueIterator_swiginit(self,_xapian.new_ValueIterator(*args))
  661.     __swig_destroy__ = _xapian.delete_ValueIterator
  662.     def get_valueno(*args):
  663.         """
  664.         Get the number of the value at the current position.
  665.  
  666.         Xapian::valueno Xapian::ValueIterator::get_valueno() const 
  667.         """
  668.         return _xapian.ValueIterator_get_valueno(*args)
  669.  
  670.     def __str__(*args):
  671.         """
  672.         Return a string describing this object.
  673.  
  674.         std::string Xapian::ValueIterator::get_description() const 
  675.         """
  676.         return _xapian.ValueIterator___str__(*args)
  677.  
  678.     def get_description(*args):
  679.         """
  680.         Return a string describing this object.
  681.  
  682.         std::string Xapian::ValueIterator::get_description() const 
  683.         """
  684.         return _xapian.ValueIterator_get_description(*args)
  685.  
  686. ValueIterator.get_value = new_instancemethod(_xapian.ValueIterator_get_value,None,ValueIterator)
  687. ValueIterator.next = new_instancemethod(_xapian.ValueIterator_next,None,ValueIterator)
  688. ValueIterator.equals = new_instancemethod(_xapian.ValueIterator_equals,None,ValueIterator)
  689. ValueIterator.get_valueno = new_instancemethod(_xapian.ValueIterator_get_valueno,None,ValueIterator)
  690. ValueIterator.__str__ = new_instancemethod(_xapian.ValueIterator___str__,None,ValueIterator)
  691. ValueIterator.get_description = new_instancemethod(_xapian.ValueIterator_get_description,None,ValueIterator)
  692. ValueIterator.__eq__ = new_instancemethod(_xapian.ValueIterator___eq__,None,ValueIterator)
  693. ValueIterator.__ne__ = new_instancemethod(_xapian.ValueIterator___ne__,None,ValueIterator)
  694. ValueIterator_swigregister = _xapian.ValueIterator_swigregister
  695. ValueIterator_swigregister(ValueIterator)
  696.  
  697. class Document(object):
  698.     """
  699.     A document in the database - holds data, values, terms, and postings.
  700.  
  701.     """
  702.     thisown = _swig_property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc='The membership flag')
  703.     __repr__ = _swig_repr
  704.     def __init__(self, *args): 
  705.         """
  706.         Make a new empty Document.
  707.  
  708.         Xapian::Document::Document() 
  709.         """
  710.         _xapian.Document_swiginit(self,_xapian.new_Document(*args))
  711.     __swig_destroy__ = _xapian.delete_Document
  712.     def get_value(*args):
  713.         """
  714.         Get value by number.
  715.  
  716.         std::string Xapian::Document::get_value(Xapian::valueno valueno) const
  717.  
  718.         Returns an empty string if no value with the given number is present
  719.         in the document.
  720.  
  721.         Parameters:
  722.         -----------
  723.  
  724.         valueno:  The number of the value. 
  725.         """
  726.         return _xapian.Document_get_value(*args)
  727.  
  728.     def add_value(*args):
  729.         """
  730.         Add a new value.
  731.  
  732.         void Xapian::Document::add_value(Xapian::valueno valueno, const
  733.         std::string &value)
  734.  
  735.         The new value will replace any existing value with the same number (or
  736.         if the new value is empty, it will remove any existing value with the
  737.         same number). 
  738.         """
  739.         return _xapian.Document_add_value(*args)
  740.  
  741.     def remove_value(*args):
  742.         """
  743.         Remove any value with the given number.
  744.  
  745.         void Xapian::Document::remove_value(Xapian::valueno valueno) 
  746.         """
  747.         return _xapian.Document_remove_value(*args)
  748.  
  749.     def clear_values(*args):
  750.         """
  751.         Remove all values associated with the document.
  752.  
  753.         void Xapian::Document::clear_values() 
  754.         """
  755.         return _xapian.Document_clear_values(*args)
  756.  
  757.     def get_data(*args):
  758.         """
  759.         Get data stored in the document.
  760.  
  761.         std::string Xapian::Document::get_data() const
  762.  
  763.         This is a potentially expensive operation, and shouldn't normally be
  764.         used in a match decider functor. Put data for use by match deciders in
  765.         a value instead. 
  766.         """
  767.         return _xapian.Document_get_data(*args)
  768.  
  769.     def set_data(*args):
  770.         """
  771.         Set data stored in the document.
  772.  
  773.         void Xapian::Document::set_data(const std::string &data) 
  774.         """
  775.         return _xapian.Document_set_data(*args)
  776.  
  777.     def add_posting(*args):
  778.         """
  779.         Add an occurrence of a term at a particular position.
  780.  
  781.         void Xapian::Document::add_posting(const std::string &tname,
  782.         Xapian::termpos tpos, Xapian::termcount wdfinc=1)
  783.  
  784.         Multiple occurrences of the term at the same position are represented
  785.         only once in the positional information, but do increase the wdf.
  786.  
  787.         If the term is not already in the document, it will be added to it.
  788.  
  789.         Parameters:
  790.         -----------
  791.  
  792.         tname:  The name of the term.
  793.  
  794.         tpos:  The position of the term.
  795.  
  796.         wdfinc:  The increment that will be applied to the wdf for this term.
  797.  
  798.         """
  799.         return _xapian.Document_add_posting(*args)
  800.  
  801.     def add_term(*args):
  802.         """
  803.         Add a term to the document, without positional information.
  804.  
  805.         void Xapian::Document::add_term(const std::string &tname,
  806.         Xapian::termcount wdfinc=1)
  807.  
  808.         Any existing positional information for the term will be left
  809.         unmodified.
  810.  
  811.         Parameters:
  812.         -----------
  813.  
  814.         tname:  The name of the term.
  815.  
  816.         wdfinc:  The increment that will be applied to the wdf for this term.
  817.  
  818.         """
  819.         return _xapian.Document_add_term(*args)
  820.  
  821.     def remove_posting(*args):
  822.         """
  823.         Remove a posting of a term from the document.
  824.  
  825.         void Xapian::Document::remove_posting(const std::string &tname,
  826.         Xapian::termpos tpos, Xapian::termcount wdfdec=1)
  827.  
  828.         Note that the term will still index the document even if all
  829.         occurrences are removed. To remove a term from a document completely,
  830.         use remove_term().
  831.  
  832.         Parameters:
  833.         -----------
  834.  
  835.         tname:  The name of the term.
  836.  
  837.         tpos:  The position of the term.
  838.  
  839.         wdfdec:  The decrement that will be applied to the wdf when removing
  840.         this posting. The wdf will not go below the value of 0.
  841.  
  842.         Parameters:
  843.         -----------
  844.  
  845.         Xapian::InvalidArgumentError:  will be thrown if the term is not at
  846.         the position specified in the position list for this term in this
  847.         document.
  848.  
  849.         Xapian::InvalidArgumentError:  will be thrown if the term is not in
  850.         the document 
  851.         """
  852.         return _xapian.Document_remove_posting(*args)
  853.  
  854.     def remove_term(*args):
  855.         """
  856.         Remove a term and all postings associated with it.
  857.  
  858.         void Xapian::Document::remove_term(const std::string &tname)
  859.  
  860.         Parameters:
  861.         -----------
  862.  
  863.         tname:  The name of the term.
  864.  
  865.         Parameters:
  866.         -----------
  867.  
  868.         Xapian::InvalidArgumentError:  will be thrown if the term is not in
  869.         the document 
  870.         """
  871.         return _xapian.Document_remove_term(*args)
  872.  
  873.     def clear_terms(*args):
  874.         """
  875.         Remove all terms (and postings) from the document.
  876.  
  877.         void Xapian::Document::clear_terms() 
  878.         """
  879.         return _xapian.Document_clear_terms(*args)
  880.  
  881.     def termlist_count(*args):
  882.         """
  883.         The length of the termlist - i.e.
  884.  
  885.         Xapian::termcount Xapian::Document::termlist_count() const
  886.  
  887.         the number of different terms which index this document. 
  888.         """
  889.         return _xapian.Document_termlist_count(*args)
  890.  
  891.     def termlist_begin(*args):
  892.         """
  893.         Iterator for the terms in this document.
  894.  
  895.         TermIterator Xapian::Document::termlist_begin() const 
  896.         """
  897.         return _xapian.Document_termlist_begin(*args)
  898.  
  899.     def termlist_end(*args):
  900.         """
  901.         Equivalent end iterator for termlist_begin().
  902.  
  903.         TermIterator Xapian::Document::termlist_end() const 
  904.         """
  905.         return _xapian.Document_termlist_end(*args)
  906.  
  907.     def values_count(*args):
  908.         """
  909.         Count the values in this document.
  910.  
  911.         Xapian::termcount Xapian::Document::values_count() const 
  912.         """
  913.         return _xapian.Document_values_count(*args)
  914.  
  915.     def values_begin(*args):
  916.         """
  917.         Iterator for the values in this document.
  918.  
  919.         ValueIterator Xapian::Document::values_begin() const 
  920.         """
  921.         return _xapian.Document_values_begin(*args)
  922.  
  923.     def values_end(*args):
  924.         """
  925.         Equivalent end iterator for values_begin().
  926.  
  927.         ValueIterator Xapian::Document::values_end() const 
  928.         """
  929.         return _xapian.Document_values_end(*args)
  930.  
  931.     def get_docid(*args):
  932.         """
  933.         Get the document id which is associated with this document (if any).
  934.  
  935.         docid Xapian::Document::get_docid() const
  936.  
  937.         NB If multiple databases are being searched together, then this will
  938.         be the document id in the individual database, not the merged
  939.         database!
  940.  
  941.         If this document came from a database, return the document id in that
  942.         database. Otherwise, return 0. 
  943.         """
  944.         return _xapian.Document_get_docid(*args)
  945.  
  946.     def __str__(*args):
  947.         """
  948.         Return a string describing this object.
  949.  
  950.         std::string Xapian::Document::get_description() const 
  951.         """
  952.         return _xapian.Document___str__(*args)
  953.  
  954.     def get_description(*args):
  955.         """
  956.         Return a string describing this object.
  957.  
  958.         std::string Xapian::Document::get_description() const 
  959.         """
  960.         return _xapian.Document_get_description(*args)
  961.  
  962. Document.get_value = new_instancemethod(_xapian.Document_get_value,None,Document)
  963. Document.add_value = new_instancemethod(_xapian.Document_add_value,None,Document)
  964. Document.remove_value = new_instancemethod(_xapian.Document_remove_value,None,Document)
  965. Document.clear_values = new_instancemethod(_xapian.Document_clear_values,None,Document)
  966. Document.get_data = new_instancemethod(_xapian.Document_get_data,None,Document)
  967. Document.set_data = new_instancemethod(_xapian.Document_set_data,None,Document)
  968. Document.add_posting = new_instancemethod(_xapian.Document_add_posting,None,Document)
  969. Document.add_term = new_instancemethod(_xapian.Document_add_term,None,Document)
  970. Document.remove_posting = new_instancemethod(_xapian.Document_remove_posting,None,Document)
  971. Document.remove_term = new_instancemethod(_xapian.Document_remove_term,None,Document)
  972. Document.clear_terms = new_instancemethod(_xapian.Document_clear_terms,None,Document)
  973. Document.termlist_count = new_instancemethod(_xapian.Document_termlist_count,None,Document)
  974. Document.termlist_begin = new_instancemethod(_xapian.Document_termlist_begin,None,Document)
  975. Document.termlist_end = new_instancemethod(_xapian.Document_termlist_end,None,Document)
  976. Document.values_count = new_instancemethod(_xapian.Document_values_count,None,Document)
  977. Document.values_begin = new_instancemethod(_xapian.Document_values_begin,None,Document)
  978. Document.values_end = new_instancemethod(_xapian.Document_values_end,None,Document)
  979. Document.get_docid = new_instancemethod(_xapian.Document_get_docid,None,Document)
  980. Document.__str__ = new_instancemethod(_xapian.Document___str__,None,Document)
  981. Document.get_description = new_instancemethod(_xapian.Document_get_description,None,Document)
  982. Document_swigregister = _xapian.Document_swigregister
  983. Document_swigregister(Document)
  984.  
  985. class MSet(object):
  986.     """
  987.     A match set ( MSet).
  988.  
  989.     This class represents (a portion of) the results of a query. 
  990.     """
  991.     thisown = _swig_property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc='The membership flag')
  992.     __repr__ = _swig_repr
  993.     def __init__(self, *args): 
  994.         """
  995.         Copying is allowed (and is cheap).
  996.  
  997.         Xapian::MSet::MSet(const MSet &other) 
  998.         """
  999.         _xapian.MSet_swiginit(self,_xapian.new_MSet(*args))
  1000.     __swig_destroy__ = _xapian.delete_MSet
  1001.     def fetch(*args):
  1002.         """
  1003.         Fetch all the items in the MSet.
  1004.  
  1005.         void Xapian::MSet::fetch() const 
  1006.         """
  1007.         return _xapian.MSet_fetch(*args)
  1008.  
  1009.     def convert_to_percent(*args):
  1010.         """
  1011.         Return the percentage score for a particular item.
  1012.  
  1013.         Xapian::percent Xapian::MSet::convert_to_percent(const MSetIterator
  1014.         &it) const 
  1015.         """
  1016.         return _xapian.MSet_convert_to_percent(*args)
  1017.  
  1018.     def get_termfreq(*args):
  1019.         """
  1020.         Return the term frequency of the given query term.
  1021.  
  1022.         Xapian::doccount Xapian::MSet::get_termfreq(const std::string &tname)
  1023.         const
  1024.  
  1025.         Parameters:
  1026.         -----------
  1027.  
  1028.         tname:  The term to look for.
  1029.  
  1030.         Parameters:
  1031.         -----------
  1032.  
  1033.         Xapian::InvalidArgumentError:  is thrown if the term was not in the
  1034.         query. 
  1035.         """
  1036.         return _xapian.MSet_get_termfreq(*args)
  1037.  
  1038.     def get_termweight(*args):
  1039.         """
  1040.         Return the term weight of the given query term.
  1041.  
  1042.         Xapian::weight Xapian::MSet::get_termweight(const std::string &tname)
  1043.         const
  1044.  
  1045.         Parameters:
  1046.         -----------
  1047.  
  1048.         tname:  The term to look for.
  1049.  
  1050.         Parameters:
  1051.         -----------
  1052.  
  1053.         Xapian::InvalidArgumentError:  is thrown if the term was not in the
  1054.         query. 
  1055.         """
  1056.         return _xapian.MSet_get_termweight(*args)
  1057.  
  1058.     def get_firstitem(*args):
  1059.         """
  1060.         The index of the first item in the result which was put into the MSet.
  1061.  
  1062.         Xapian::doccount Xapian::MSet::get_firstitem() const
  1063.  
  1064.         This corresponds to the parameter "first" specified in
  1065.         Xapian::Enquire::get_mset(). A value of 0 corresponds to the highest
  1066.         result being the first item in the MSet. 
  1067.         """
  1068.         return _xapian.MSet_get_firstitem(*args)
  1069.  
  1070.     def get_matches_lower_bound(*args):
  1071.         """
  1072.         A lower bound on the number of documents in the database which match
  1073.         the query.
  1074.  
  1075.         Xapian::doccount Xapian::MSet::get_matches_lower_bound() const
  1076.  
  1077.         This figure takes into account collapsing of duplicates, and weighting
  1078.         cutoff values.
  1079.  
  1080.         This number is usually considerably less than the actual number of
  1081.         documents which match the query. 
  1082.         """
  1083.         return _xapian.MSet_get_matches_lower_bound(*args)
  1084.  
  1085.     def get_matches_estimated(*args):
  1086.         """
  1087.         An estimate for the number of documents in the database which match
  1088.         the query.
  1089.  
  1090.         Xapian::doccount Xapian::MSet::get_matches_estimated() const
  1091.  
  1092.         This figure takes into account collapsing of duplicates, and weighting
  1093.         cutoff values.
  1094.  
  1095.         This value is returned because there is sometimes a request to display
  1096.         such information. However, our experience is that presenting this
  1097.         value to users causes them to worry about the large number of results,
  1098.         rather than how useful those at the top of the result set are, and is
  1099.         thus undesirable. 
  1100.         """
  1101.         return _xapian.MSet_get_matches_estimated(*args)
  1102.  
  1103.     def get_matches_upper_bound(*args):
  1104.         """
  1105.         An upper bound on the number of documents in the database which match
  1106.         the query.
  1107.  
  1108.         Xapian::doccount Xapian::MSet::get_matches_upper_bound() const
  1109.  
  1110.         This figure takes into account collapsing of duplicates, and weighting
  1111.         cutoff values.
  1112.  
  1113.         This number is usually considerably greater than the actual number of
  1114.         documents which match the query. 
  1115.         """
  1116.         return _xapian.MSet_get_matches_upper_bound(*args)
  1117.  
  1118.     def get_max_possible(*args):
  1119.         """
  1120.         The maximum possible weight in the MSet.
  1121.  
  1122.         Xapian::weight Xapian::MSet::get_max_possible() const
  1123.  
  1124.         This weight is likely not to be attained in the set of results, but
  1125.         represents an upper bound on the weight which a document could attain
  1126.         for the given query. 
  1127.         """
  1128.         return _xapian.MSet_get_max_possible(*args)
  1129.  
  1130.     def get_max_attained(*args):
  1131.         """
  1132.         The greatest weight which is attained by any document in the database.
  1133.  
  1134.         Xapian::weight Xapian::MSet::get_max_attained() const
  1135.  
  1136.         If firstitem == 0 and the primary ordering is by relevance, this is
  1137.         the weight of the first entry in the MSet.
  1138.  
  1139.         If no documents are found by the query, this will be 0.
  1140.  
  1141.         Note that calculation of max_attained requires calculation of at least
  1142.         one result item - therefore, if no items were requested when the query
  1143.         was performed (by specifying maxitems = 0 in
  1144.         Xapian::Enquire::get_mset()), this value will be 0. 
  1145.         """
  1146.         return _xapian.MSet_get_max_attained(*args)
  1147.  
  1148.     def size(*args):
  1149.         """
  1150.         The number of items in this MSet.
  1151.  
  1152.         Xapian::doccount Xapian::MSet::size() const 
  1153.         """
  1154.         return _xapian.MSet_size(*args)
  1155.  
  1156.     def empty(*args):
  1157.         """
  1158.         Test if this MSet is empty.
  1159.  
  1160.         bool Xapian::MSet::empty() const 
  1161.         """
  1162.         return _xapian.MSet_empty(*args)
  1163.  
  1164.     def begin(*args):
  1165.         """
  1166.         Iterator for the terms in this MSet.
  1167.  
  1168.         MSetIterator Xapian::MSet::begin() const 
  1169.         """
  1170.         return _xapian.MSet_begin(*args)
  1171.  
  1172.     def end(*args):
  1173.         """
  1174.         End iterator corresponding to begin().
  1175.  
  1176.         MSetIterator Xapian::MSet::end() const 
  1177.         """
  1178.         return _xapian.MSet_end(*args)
  1179.  
  1180.     def back(*args):
  1181.         """
  1182.         Iterator pointing to the last element of this MSet.
  1183.  
  1184.         MSetIterator Xapian::MSet::back() const 
  1185.         """
  1186.         return _xapian.MSet_back(*args)
  1187.  
  1188.     def _get_hit_internal(*args):
  1189.         """
  1190.         Get an item from the MSet.
  1191.  
  1192.         The supplied index is relative to the start of the MSet, not the absolute rank
  1193.         of the item. 
  1194.         """
  1195.         return _xapian.MSet__get_hit_internal(*args)
  1196.  
  1197.     def __str__(*args):
  1198.         """
  1199.         Return a string describing this object.
  1200.  
  1201.         std::string Xapian::MSet::get_description() const 
  1202.         """
  1203.         return _xapian.MSet___str__(*args)
  1204.  
  1205.     def get_description(*args):
  1206.         """
  1207.         Return a string describing this object.
  1208.  
  1209.         std::string Xapian::MSet::get_description() const 
  1210.         """
  1211.         return _xapian.MSet_get_description(*args)
  1212.  
  1213.     items = _swig_property(_xapian.MSet_items_get)
  1214. MSet.fetch = new_instancemethod(_xapian.MSet_fetch,None,MSet)
  1215. MSet.convert_to_percent = new_instancemethod(_xapian.MSet_convert_to_percent,None,MSet)
  1216. MSet.get_termfreq = new_instancemethod(_xapian.MSet_get_termfreq,None,MSet)
  1217. MSet.get_termweight = new_instancemethod(_xapian.MSet_get_termweight,None,MSet)
  1218. MSet.get_firstitem = new_instancemethod(_xapian.MSet_get_firstitem,None,MSet)
  1219. MSet.get_matches_lower_bound = new_instancemethod(_xapian.MSet_get_matches_lower_bound,None,MSet)
  1220. MSet.get_matches_estimated = new_instancemethod(_xapian.MSet_get_matches_estimated,None,MSet)
  1221. MSet.get_matches_upper_bound = new_instancemethod(_xapian.MSet_get_matches_upper_bound,None,MSet)
  1222. MSet.get_max_possible = new_instancemethod(_xapian.MSet_get_max_possible,None,MSet)
  1223. MSet.get_max_attained = new_instancemethod(_xapian.MSet_get_max_attained,None,MSet)
  1224. MSet.size = new_instancemethod(_xapian.MSet_size,None,MSet)
  1225. MSet.empty = new_instancemethod(_xapian.MSet_empty,None,MSet)
  1226. MSet.begin = new_instancemethod(_xapian.MSet_begin,None,MSet)
  1227. MSet.end = new_instancemethod(_xapian.MSet_end,None,MSet)
  1228. MSet.back = new_instancemethod(_xapian.MSet_back,None,MSet)
  1229. MSet._get_hit_internal = new_instancemethod(_xapian.MSet__get_hit_internal,None,MSet)
  1230. MSet.get_document_percentage = new_instancemethod(_xapian.MSet_get_document_percentage,None,MSet)
  1231. MSet.get_document = new_instancemethod(_xapian.MSet_get_document,None,MSet)
  1232. MSet.get_docid = new_instancemethod(_xapian.MSet_get_docid,None,MSet)
  1233. MSet.get_document_id = new_instancemethod(_xapian.MSet_get_document_id,None,MSet)
  1234. MSet.__str__ = new_instancemethod(_xapian.MSet___str__,None,MSet)
  1235. MSet.get_description = new_instancemethod(_xapian.MSet_get_description,None,MSet)
  1236. MSet.__cmp__ = new_instancemethod(_xapian.MSet___cmp__,None,MSet)
  1237. MSet_swigregister = _xapian.MSet_swigregister
  1238. MSet_swigregister(MSet)
  1239.  
  1240. class MSetIterator(object):
  1241.     """
  1242.     An iterator pointing to items in an MSet.
  1243.  
  1244.     This is used for access to individual results of a match. 
  1245.     """
  1246.     thisown = _swig_property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc='The membership flag')
  1247.     __repr__ = _swig_repr
  1248.     def __init__(self, *args): 
  1249.         """
  1250.         Copying is allowed (and is cheap).
  1251.  
  1252.         Xapian::MSetIterator::MSetIterator(const MSetIterator &other) 
  1253.         """
  1254.         _xapian.MSetIterator_swiginit(self,_xapian.new_MSetIterator(*args))
  1255.     __swig_destroy__ = _xapian.delete_MSetIterator
  1256.     def get_document(*args):
  1257.         """
  1258.         Get a Xapian::Document object for the current position.
  1259.  
  1260.         Xapian::Document Xapian::MSetIterator::get_document() const
  1261.  
  1262.         This method returns a Xapian::Document object which provides the
  1263.         information about the document pointed to by the MSetIterator.
  1264.  
  1265.         If the underlying database has suitable support, using this call
  1266.         (rather than asking the database for a document based on its document
  1267.         ID) will enable the system to ensure that the correct data is
  1268.         returned, and that the document has not been deleted or changed since
  1269.         the query was performed.
  1270.  
  1271.         A Xapian::Document object containing the document data.
  1272.  
  1273.         Parameters:
  1274.         -----------
  1275.  
  1276.         Xapian::DocNotFoundError:  The document specified could not be found
  1277.         in the database. 
  1278.         """
  1279.         return _xapian.MSetIterator_get_document(*args)
  1280.  
  1281.     def get_rank(*args):
  1282.         """
  1283.         Get the rank of the document at the current position.
  1284.  
  1285.         Xapian::doccount Xapian::MSetIterator::get_rank() const
  1286.  
  1287.         The rank is the position that this document is at in the ordered list
  1288.         of results of the query. The result is 0-based - i.e. the top-ranked
  1289.         document has a rank of 0. 
  1290.         """
  1291.         return _xapian.MSetIterator_get_rank(*args)
  1292.  
  1293.     def get_weight(*args):
  1294.         """
  1295.         Get the weight of the document at the current position.
  1296.  
  1297.         Xapian::weight Xapian::MSetIterator::get_weight() const 
  1298.         """
  1299.         return _xapian.MSetIterator_get_weight(*args)
  1300.  
  1301.     def get_collapse_key(*args):
  1302.         """
  1303.         Get the collapse key for this document.
  1304.  
  1305.         std::string Xapian::MSetIterator::get_collapse_key() const 
  1306.         """
  1307.         return _xapian.MSetIterator_get_collapse_key(*args)
  1308.  
  1309.     def get_collapse_count(*args):
  1310.         """
  1311.         Get an estimate of the number of documents that have been collapsed
  1312.         into this one.
  1313.  
  1314.         Xapian::doccount Xapian::MSetIterator::get_collapse_count() const
  1315.  
  1316.         The estimate will always be less than or equal to the actual number of
  1317.         other documents satisfying the match criteria with the same collapse
  1318.         key as this document.
  1319.  
  1320.         This method may return 0 even though there are other documents with
  1321.         the same collapse key which satisfying the match criteria. However if
  1322.         this method returns non-zero, there definitely are other such
  1323.         documents. So this method may be used to inform the user that there
  1324.         are "at least N other matches in this group", or to control whether
  1325.         to offer a "show other documents in this group" feature (but note
  1326.         that it may not offer it in every case where it would show other
  1327.         documents). 
  1328.         """
  1329.         return _xapian.MSetIterator_get_collapse_count(*args)
  1330.  
  1331.     def get_percent(*args):
  1332.         """
  1333.         This returns the weight of the document as a percentage score.
  1334.  
  1335.         Xapian::percent Xapian::MSetIterator::get_percent() const
  1336.  
  1337.         The return value will be an integer in the range 0 to 100: 0 meaning
  1338.         that the item did not match the query at all.
  1339.  
  1340.         The intention is that the highest weighted document will get 100 if it
  1341.         matches all the weight-contributing terms in the query. However,
  1342.         currently it may get a lower percentage score if you use a
  1343.         MatchDecider and the sorting is primarily by value. In this case, the
  1344.         percentage for a particular document may vary depending on the first,
  1345.         max_size, and checkatleast parameters passed to Enquire::get_mset()
  1346.         (this bug is hard to fix without having to apply the MatchDecider to
  1347.         potentially many more documents, which is potentially costly). 
  1348.         """
  1349.         return _xapian.MSetIterator_get_percent(*args)
  1350.  
  1351.     def __str__(*args):
  1352.         """
  1353.         Return a string describing this object.
  1354.  
  1355.         std::string Xapian::MSetIterator::get_description() const 
  1356.         """
  1357.         return _xapian.MSetIterator___str__(*args)
  1358.  
  1359.     def get_description(*args):
  1360.         """
  1361.         Return a string describing this object.
  1362.  
  1363.         std::string Xapian::MSetIterator::get_description() const 
  1364.         """
  1365.         return _xapian.MSetIterator_get_description(*args)
  1366.  
  1367. MSetIterator.get_docid = new_instancemethod(_xapian.MSetIterator_get_docid,None,MSetIterator)
  1368. MSetIterator.next = new_instancemethod(_xapian.MSetIterator_next,None,MSetIterator)
  1369. MSetIterator.prev = new_instancemethod(_xapian.MSetIterator_prev,None,MSetIterator)
  1370. MSetIterator.equals = new_instancemethod(_xapian.MSetIterator_equals,None,MSetIterator)
  1371. MSetIterator.get_document = new_instancemethod(_xapian.MSetIterator_get_document,None,MSetIterator)
  1372. MSetIterator.get_rank = new_instancemethod(_xapian.MSetIterator_get_rank,None,MSetIterator)
  1373. MSetIterator.get_weight = new_instancemethod(_xapian.MSetIterator_get_weight,None,MSetIterator)
  1374. MSetIterator.get_collapse_key = new_instancemethod(_xapian.MSetIterator_get_collapse_key,None,MSetIterator)
  1375. MSetIterator.get_collapse_count = new_instancemethod(_xapian.MSetIterator_get_collapse_count,None,MSetIterator)
  1376. MSetIterator.get_percent = new_instancemethod(_xapian.MSetIterator_get_percent,None,MSetIterator)
  1377. MSetIterator.__str__ = new_instancemethod(_xapian.MSetIterator___str__,None,MSetIterator)
  1378. MSetIterator.get_description = new_instancemethod(_xapian.MSetIterator_get_description,None,MSetIterator)
  1379. MSetIterator.__eq__ = new_instancemethod(_xapian.MSetIterator___eq__,None,MSetIterator)
  1380. MSetIterator.__ne__ = new_instancemethod(_xapian.MSetIterator___ne__,None,MSetIterator)
  1381. MSetIterator_swigregister = _xapian.MSetIterator_swigregister
  1382. MSetIterator_swigregister(MSetIterator)
  1383.  
  1384. class ESet(object):
  1385.     """
  1386.     Class representing an ordered set of expand terms (an ESet).
  1387.  
  1388.     This set represents the results of an expand operation, which is
  1389.     performed by Xapian::Enquire::get_eset(). 
  1390.     """
  1391.     thisown = _swig_property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc='The membership flag')
  1392.     __repr__ = _swig_repr
  1393.     def __init__(self, *args): 
  1394.         """
  1395.         Copying is allowed (and is cheap).
  1396.  
  1397.         Xapian::ESet::ESet(const ESet &other) 
  1398.         """
  1399.         _xapian.ESet_swiginit(self,_xapian.new_ESet(*args))
  1400.     __swig_destroy__ = _xapian.delete_ESet
  1401.     def get_ebound(*args):
  1402.         """
  1403.         A lower bound on the number of terms which are in the full set of
  1404.         results of the expand.
  1405.  
  1406.         Xapian::termcount Xapian::ESet::get_ebound() const
  1407.  
  1408.         This will be greater than or equal to size() 
  1409.         """
  1410.         return _xapian.ESet_get_ebound(*args)
  1411.  
  1412.     def size(*args):
  1413.         """
  1414.         The number of terms in this E-Set.
  1415.  
  1416.         Xapian::termcount Xapian::ESet::size() const 
  1417.         """
  1418.         return _xapian.ESet_size(*args)
  1419.  
  1420.     def empty(*args):
  1421.         """
  1422.         Test if this E-Set is empty.
  1423.  
  1424.         bool Xapian::ESet::empty() const 
  1425.         """
  1426.         return _xapian.ESet_empty(*args)
  1427.  
  1428.     def begin(*args):
  1429.         """
  1430.         Iterator for the terms in this E-Set.
  1431.  
  1432.         ESetIterator Xapian::ESet::begin() const 
  1433.         """
  1434.         return _xapian.ESet_begin(*args)
  1435.  
  1436.     def end(*args):
  1437.         """
  1438.         End iterator corresponding to begin().
  1439.  
  1440.         ESetIterator Xapian::ESet::end() const 
  1441.         """
  1442.         return _xapian.ESet_end(*args)
  1443.  
  1444.     def back(*args):
  1445.         """
  1446.         Iterator pointing to the last element of this E-Set.
  1447.  
  1448.         ESetIterator Xapian::ESet::back() const 
  1449.         """
  1450.         return _xapian.ESet_back(*args)
  1451.  
  1452.     def __str__(*args):
  1453.         """
  1454.         Return a string describing this object.
  1455.  
  1456.         std::string Xapian::ESet::get_description() const 
  1457.         """
  1458.         return _xapian.ESet___str__(*args)
  1459.  
  1460.     def get_description(*args):
  1461.         """
  1462.         Return a string describing this object.
  1463.  
  1464.         std::string Xapian::ESet::get_description() const 
  1465.         """
  1466.         return _xapian.ESet_get_description(*args)
  1467.  
  1468.     items = _swig_property(_xapian.ESet_items_get)
  1469. ESet.get_ebound = new_instancemethod(_xapian.ESet_get_ebound,None,ESet)
  1470. ESet.size = new_instancemethod(_xapian.ESet_size,None,ESet)
  1471. ESet.empty = new_instancemethod(_xapian.ESet_empty,None,ESet)
  1472. ESet.begin = new_instancemethod(_xapian.ESet_begin,None,ESet)
  1473. ESet.end = new_instancemethod(_xapian.ESet_end,None,ESet)
  1474. ESet.back = new_instancemethod(_xapian.ESet_back,None,ESet)
  1475. ESet.__str__ = new_instancemethod(_xapian.ESet___str__,None,ESet)
  1476. ESet.get_description = new_instancemethod(_xapian.ESet_get_description,None,ESet)
  1477. ESet_swigregister = _xapian.ESet_swigregister
  1478. ESet_swigregister(ESet)
  1479.  
  1480. class ESetIterator(object):
  1481.     """
  1482.     Iterate through terms in the ESet. 
  1483.     """
  1484.     thisown = _swig_property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc='The membership flag')
  1485.     __repr__ = _swig_repr
  1486.     def __init__(self, *args): 
  1487.         """
  1488.         Copying is allowed (and is cheap).
  1489.  
  1490.         Xapian::ESetIterator::ESetIterator(const ESetIterator &other) 
  1491.         """
  1492.         _xapian.ESetIterator_swiginit(self,_xapian.new_ESetIterator(*args))
  1493.     __swig_destroy__ = _xapian.delete_ESetIterator
  1494.     def get_weight(*args):
  1495.         """
  1496.         Get the weight of the term at the current position.
  1497.  
  1498.         Xapian::weight Xapian::ESetIterator::get_weight() const 
  1499.         """
  1500.         return _xapian.ESetIterator_get_weight(*args)
  1501.  
  1502.     def __str__(*args):
  1503.         """
  1504.         Return a string describing this object.
  1505.  
  1506.         std::string Xapian::ESetIterator::get_description() const 
  1507.         """
  1508.         return _xapian.ESetIterator___str__(*args)
  1509.  
  1510.     def get_description(*args):
  1511.         """
  1512.         Return a string describing this object.
  1513.  
  1514.         std::string Xapian::ESetIterator::get_description() const 
  1515.         """
  1516.         return _xapian.ESetIterator_get_description(*args)
  1517.  
  1518. ESetIterator.get_termname = new_instancemethod(_xapian.ESetIterator_get_termname,None,ESetIterator)
  1519. ESetIterator.get_term = new_instancemethod(_xapian.ESetIterator_get_term,None,ESetIterator)
  1520. ESetIterator.next = new_instancemethod(_xapian.ESetIterator_next,None,ESetIterator)
  1521. ESetIterator.prev = new_instancemethod(_xapian.ESetIterator_prev,None,ESetIterator)
  1522. ESetIterator.equals = new_instancemethod(_xapian.ESetIterator_equals,None,ESetIterator)
  1523. ESetIterator.get_weight = new_instancemethod(_xapian.ESetIterator_get_weight,None,ESetIterator)
  1524. ESetIterator.__str__ = new_instancemethod(_xapian.ESetIterator___str__,None,ESetIterator)
  1525. ESetIterator.get_description = new_instancemethod(_xapian.ESetIterator_get_description,None,ESetIterator)
  1526. ESetIterator.__eq__ = new_instancemethod(_xapian.ESetIterator___eq__,None,ESetIterator)
  1527. ESetIterator.__ne__ = new_instancemethod(_xapian.ESetIterator___ne__,None,ESetIterator)
  1528. ESetIterator_swigregister = _xapian.ESetIterator_swigregister
  1529. ESetIterator_swigregister(ESetIterator)
  1530.  
  1531. class RSet(object):
  1532.     """
  1533.     A relevance set (R-Set).
  1534.  
  1535.     This is the set of documents which are marked as relevant, for use in
  1536.     modifying the term weights, and in performing query expansion. 
  1537.     """
  1538.     thisown = _swig_property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc='The membership flag')
  1539.     __repr__ = _swig_repr
  1540.     def __init__(self, *args): 
  1541.         """
  1542.         Default constructor.
  1543.  
  1544.         Xapian::RSet::RSet() 
  1545.         """
  1546.         _xapian.RSet_swiginit(self,_xapian.new_RSet(*args))
  1547.     __swig_destroy__ = _xapian.delete_RSet
  1548.     def size(*args):
  1549.         """
  1550.         The number of documents in this R-Set.
  1551.  
  1552.         Xapian::doccount Xapian::RSet::size() const 
  1553.         """
  1554.         return _xapian.RSet_size(*args)
  1555.  
  1556.     def empty(*args):
  1557.         """
  1558.         Test if this R-Set is empty.
  1559.  
  1560.         bool Xapian::RSet::empty() const 
  1561.         """
  1562.         return _xapian.RSet_empty(*args)
  1563.  
  1564.     def add_document(*args):
  1565.         """
  1566.         Add a document to the relevance set.
  1567.  
  1568.         void Xapian::RSet::add_document(const Xapian::MSetIterator &i) 
  1569.         """
  1570.         return _xapian.RSet_add_document(*args)
  1571.  
  1572.     def remove_document(*args):
  1573.         """
  1574.         Remove a document from the relevance set.
  1575.  
  1576.         void Xapian::RSet::remove_document(const Xapian::MSetIterator &i) 
  1577.         """
  1578.         return _xapian.RSet_remove_document(*args)
  1579.  
  1580.     def contains(*args):
  1581.         """
  1582.         Test if a given document in the relevance set.
  1583.  
  1584.         bool Xapian::RSet::contains(const Xapian::MSetIterator &i) const 
  1585.         """
  1586.         return _xapian.RSet_contains(*args)
  1587.  
  1588.     def __str__(*args):
  1589.         """
  1590.         Return a string describing this object.
  1591.  
  1592.         std::string Xapian::RSet::get_description() const 
  1593.         """
  1594.         return _xapian.RSet___str__(*args)
  1595.  
  1596.     def get_description(*args):
  1597.         """
  1598.         Return a string describing this object.
  1599.  
  1600.         std::string Xapian::RSet::get_description() const 
  1601.         """
  1602.         return _xapian.RSet_get_description(*args)
  1603.  
  1604. RSet.size = new_instancemethod(_xapian.RSet_size,None,RSet)
  1605. RSet.empty = new_instancemethod(_xapian.RSet_empty,None,RSet)
  1606. RSet.add_document = new_instancemethod(_xapian.RSet_add_document,None,RSet)
  1607. RSet.remove_document = new_instancemethod(_xapian.RSet_remove_document,None,RSet)
  1608. RSet.contains = new_instancemethod(_xapian.RSet_contains,None,RSet)
  1609. RSet.__str__ = new_instancemethod(_xapian.RSet___str__,None,RSet)
  1610. RSet.get_description = new_instancemethod(_xapian.RSet_get_description,None,RSet)
  1611. RSet_swigregister = _xapian.RSet_swigregister
  1612. RSet_swigregister(RSet)
  1613.  
  1614. class MatchDecider(object):
  1615.     """
  1616.     Base class for matcher decision functor. 
  1617.     """
  1618.     thisown = _swig_property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc='The membership flag')
  1619.     __repr__ = _swig_repr
  1620.     __swig_destroy__ = _xapian.delete_MatchDecider
  1621.     def __init__(self, *args): 
  1622.         if self.__class__ == MatchDecider:
  1623.             args = (None,) + args
  1624.         else:
  1625.             args = (self,) + args
  1626.         _xapian.MatchDecider_swiginit(self,_xapian.new_MatchDecider(*args))
  1627.     def __disown__(self):
  1628.         self.this.disown()
  1629.         _xapian.disown_MatchDecider(self)
  1630.         return weakref_proxy(self)
  1631. MatchDecider.__call__ = new_instancemethod(_xapian.MatchDecider___call__,None,MatchDecider)
  1632. MatchDecider_swigregister = _xapian.MatchDecider_swigregister
  1633. MatchDecider_swigregister(MatchDecider)
  1634.  
  1635. class ExpandDecider(object):
  1636.     """
  1637.     Virtual base class for expand decider functor. 
  1638.     """
  1639.     thisown = _swig_property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc='The membership flag')
  1640.     __repr__ = _swig_repr
  1641.     __swig_destroy__ = _xapian.delete_ExpandDecider
  1642.     def __init__(self, *args): 
  1643.         if self.__class__ == ExpandDecider:
  1644.             args = (None,) + args
  1645.         else:
  1646.             args = (self,) + args
  1647.         _xapian.ExpandDecider_swiginit(self,_xapian.new_ExpandDecider(*args))
  1648.     def __disown__(self):
  1649.         self.this.disown()
  1650.         _xapian.disown_ExpandDecider(self)
  1651.         return weakref_proxy(self)
  1652. ExpandDecider.__call__ = new_instancemethod(_xapian.ExpandDecider___call__,None,ExpandDecider)
  1653. ExpandDecider_swigregister = _xapian.ExpandDecider_swigregister
  1654. ExpandDecider_swigregister(ExpandDecider)
  1655.  
  1656. class Enquire(object):
  1657.     """
  1658.     This class provides an interface to the information retrieval system
  1659.     for the purpose of searching.
  1660.  
  1661.     Databases are usually opened lazily, so exceptions may not be thrown
  1662.     where you would expect them to be. You should catch Xapian::Error
  1663.     exceptions when calling any method in Xapian::Enquire.
  1664.  
  1665.     Parameters:
  1666.     -----------
  1667.  
  1668.     Xapian::InvalidArgumentError:  will be thrown if an invalid argument
  1669.     is supplied, for example, an unknown database type. 
  1670.     """
  1671.     thisown = _swig_property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc='The membership flag')
  1672.     __repr__ = _swig_repr
  1673.     def __init__(self, *args): 
  1674.         """
  1675.         Create a Xapian::Enquire object.
  1676.  
  1677.         Xapian::Enquire::Enquire(const Database &database, ErrorHandler
  1678.         *errorhandler_=0)
  1679.  
  1680.         This specification cannot be changed once the Xapian::Enquire is
  1681.         opened: you must create a new Xapian::Enquire object to access a
  1682.         different database, or set of databases.
  1683.  
  1684.         The database supplied must have been initialised (ie, must not be the
  1685.         result of calling the Database::Database() constructor). If you need
  1686.         to handle a situation where you have no index gracefully, a database
  1687.         created with InMemory::open() can be passed here, which represents a
  1688.         completely empty database.
  1689.  
  1690.         Parameters:
  1691.         -----------
  1692.  
  1693.         database:  Specification of the database or databases to use.
  1694.  
  1695.         errorhandler_:  A pointer to the error handler to use. Ownership of
  1696.         the object pointed to is not assumed by the Xapian::Enquire object -
  1697.         the user should delete the Xapian::ErrorHandler object after the
  1698.         Xapian::Enquire object is deleted. To use no error handler, this
  1699.         parameter should be 0.
  1700.  
  1701.         Parameters:
  1702.         -----------
  1703.  
  1704.         Xapian::InvalidArgumentError:  will be thrown if an initialised
  1705.         Database object is supplied. 
  1706.         """
  1707.         _xapian.Enquire_swiginit(self,_xapian.new_Enquire(*args))
  1708.     __swig_destroy__ = _xapian.delete_Enquire
  1709.     def set_query(*args):
  1710.         """
  1711.         Set the query to run.
  1712.  
  1713.         void Xapian::Enquire::set_query(const Xapian::Query &query,
  1714.         Xapian::termcount qlen=0)
  1715.  
  1716.         Parameters:
  1717.         -----------
  1718.  
  1719.         query:  the new query to run.
  1720.  
  1721.         qlen:  the query length to use in weight calculations - by default the
  1722.         sum of the wqf of all terms is used. 
  1723.         """
  1724.         return _xapian.Enquire_set_query(*args)
  1725.  
  1726.     def get_query(*args):
  1727.         """
  1728.         Get the query which has been set.
  1729.  
  1730.         const Xapian::Query& Xapian::Enquire::get_query() const
  1731.  
  1732.         This is only valid after set_query() has been called.
  1733.  
  1734.         Parameters:
  1735.         -----------
  1736.  
  1737.         Xapian::InvalidArgumentError:  will be thrown if query has not yet
  1738.         been set. 
  1739.         """
  1740.         return _xapian.Enquire_get_query(*args)
  1741.  
  1742.     def set_weighting_scheme(*args):
  1743.         """
  1744.         Set the weighting scheme to use for queries.
  1745.  
  1746.         void Xapian::Enquire::set_weighting_scheme(const Weight &weight_)
  1747.  
  1748.         Parameters:
  1749.         -----------
  1750.  
  1751.         weight_:  the new weighting scheme. If no weighting scheme is
  1752.         specified, the default is BM25 with the default parameters. 
  1753.         """
  1754.         return _xapian.Enquire_set_weighting_scheme(*args)
  1755.  
  1756.     def set_collapse_key(*args):
  1757.         """
  1758.         Set the collapse key to use for queries.
  1759.  
  1760.         void Xapian::Enquire::set_collapse_key(Xapian::valueno collapse_key)
  1761.  
  1762.         Parameters:
  1763.         -----------
  1764.  
  1765.         collapse_key:  value number to collapse on - at most one MSet entry
  1766.         with each particular value will be returned.
  1767.  
  1768.         The entry returned will be the best entry with that particular value
  1769.         (highest weight or highest sorting key).
  1770.  
  1771.         An example use might be to create a value for each document containing
  1772.         an MD5 hash of the document contents. Then duplicate documents from
  1773.         different sources can be eliminated at search time (it's better to
  1774.         eliminate duplicates at index time, but this may not be always be
  1775.         possible - for example the search may be over more than one Xapian
  1776.         database).
  1777.  
  1778.         Another use is to group matches in a particular category (e.g. you
  1779.         might collapse a mailing list search on the Subject: so that there's
  1780.         only one result per discussion thread). In this case you can use
  1781.         get_collapse_count() to give the user some idea how many other results
  1782.         there are. And if you index the Subject: as a boolean term as well as
  1783.         putting it in a value, you can offer a link to a non-collapsed search
  1784.         restricted to that thread using a boolean filter.
  1785.  
  1786.         (default is Xapian::BAD_VALUENO which means no collapsing). 
  1787.         """
  1788.         return _xapian.Enquire_set_collapse_key(*args)
  1789.  
  1790.     ASCENDING = _xapian.Enquire_ASCENDING
  1791.     DESCENDING = _xapian.Enquire_DESCENDING
  1792.     DONT_CARE = _xapian.Enquire_DONT_CARE
  1793.     def set_docid_order(*args):
  1794.         """
  1795.         Set the direction in which documents are ordered by document id in the
  1796.         returned MSet.
  1797.  
  1798.         void Xapian::Enquire::set_docid_order(docid_order order)
  1799.  
  1800.         This order only has an effect on documents which would otherwise have
  1801.         equal rank. For a weighted probabilistic match with no sort value,
  1802.         this means documents with equal weight. For a boolean match, with no
  1803.         sort value, this means all documents. And if a sort value is used,
  1804.         this means documents with equal sort value (and also equal weight if
  1805.         ordering on relevance after the sort).
  1806.  
  1807.         Parameters:
  1808.         -----------
  1809.  
  1810.         order:  This can be: Xapian::Enquire::ASCENDING docids sort in
  1811.         ascending order (default)
  1812.  
  1813.         Xapian::Enquire::DESCENDING docids sort in descending order
  1814.  
  1815.         Xapian::Enquire::DONT_CARE docids sort in whatever order is most
  1816.         efficient for the backend
  1817.  
  1818.         Note: If you add documents in strict date order, then a boolean search
  1819.         - i.e. set_weighting_scheme(Xapian::BoolWeight()) - with
  1820.         set_docid_order(Xapian::Enquire::DESCENDING) is a very efficient way
  1821.         to perform "sort by date, newest first". 
  1822.         """
  1823.         return _xapian.Enquire_set_docid_order(*args)
  1824.  
  1825.     def set_cutoff(*args):
  1826.         """
  1827.         Set the percentage and/or weight cutoffs.
  1828.  
  1829.         void Xapian::Enquire::set_cutoff(Xapian::percent percent_cutoff,
  1830.         Xapian::weight weight_cutoff=0)
  1831.  
  1832.         Parameters:
  1833.         -----------
  1834.  
  1835.         percent_cutoff:  Minimum percentage score for returned documents. If a
  1836.         document has a lower percentage score than this, it will not appear in
  1837.         the MSet. If your intention is to return only matches which contain
  1838.         all the terms in the query, then it's more efficient to use
  1839.         Xapian::Query::OP_AND instead of Xapian::Query::OP_OR in the query
  1840.         than to use set_cutoff(100). (default 0 => no percentage cut-off).
  1841.  
  1842.         weight_cutoff:  Minimum weight for a document to be returned. If a
  1843.         document has a lower score that this, it will not appear in the MSet.
  1844.         It is usually only possible to choose an appropriate weight for cutoff
  1845.         based on the results of a previous run of the same query; this is thus
  1846.         mainly useful for alerting operations. The other potential use is with
  1847.         a user specified weighting scheme. (default 0 => no weight cut-off).
  1848.  
  1849.         """
  1850.         return _xapian.Enquire_set_cutoff(*args)
  1851.  
  1852.     def set_sort_by_relevance(*args):
  1853.         """
  1854.         Set the sorting to be by relevance only.
  1855.  
  1856.         void Xapian::Enquire::set_sort_by_relevance()
  1857.  
  1858.         This is the default. 
  1859.         """
  1860.         return _xapian.Enquire_set_sort_by_relevance(*args)
  1861.  
  1862.     def set_sort_by_value(*args):
  1863.         """
  1864.         Set the sorting to be by value only.
  1865.  
  1866.         void Xapian::Enquire::set_sort_by_value(Xapian::valueno sort_key, bool
  1867.         reverse=true)
  1868.  
  1869.         NB sorting of values uses a string comparison, so you'll need to store
  1870.         numbers padded with leading zeros or spaces, or with the number of
  1871.         digits prepended.
  1872.  
  1873.         Parameters:
  1874.         -----------
  1875.  
  1876.         sort_key:  value number to sort on.
  1877.  
  1878.         reverse:  If true, reverses the sort order. (default true, but this
  1879.         default is confusing and deprecated in 1.1.0, so we recommend
  1880.         specifying this parameter explicitly). 
  1881.         """
  1882.         return _xapian.Enquire_set_sort_by_value(*args)
  1883.  
  1884.     def set_sort_by_value_then_relevance(*args):
  1885.         """
  1886.         Set the sorting to be by value, then by relevance for documents with
  1887.         the same value.
  1888.  
  1889.         void Xapian::Enquire::set_sort_by_value_then_relevance(Xapian::valueno
  1890.         sort_key, bool reverse=true)
  1891.  
  1892.         NB sorting of values uses a string comparison, so you'll need to store
  1893.         numbers padded with leading zeros or spaces, or with the number of
  1894.         digits prepended.
  1895.  
  1896.         Parameters:
  1897.         -----------
  1898.  
  1899.         sort_key:  value number to sort on.
  1900.  
  1901.         reverse:  If true, reverses the sort order. (default true, but this
  1902.         default is confusing and deprecated in 1.1.0, so we recommend
  1903.         specifying this parameter explicitly). 
  1904.         """
  1905.         return _xapian.Enquire_set_sort_by_value_then_relevance(*args)
  1906.  
  1907.     def set_sort_by_relevance_then_value(*args):
  1908.         """
  1909.         Set the sorting to be by relevance then value.
  1910.  
  1911.         void Xapian::Enquire::set_sort_by_relevance_then_value(Xapian::valueno
  1912.         sort_key, bool reverse=true)
  1913.  
  1914.         NB sorting of values uses a string comparison, so you'll need to store
  1915.         numbers padded with leading zeros or spaces, or with the number of
  1916.         digits prepended.
  1917.  
  1918.         Note that with the default BM25 weighting scheme parameters, non-
  1919.         identical documents will rarely have the same weight, so this setting
  1920.         will give very similar results to set_sort_by_relevance(). It becomes
  1921.         more useful with particular BM25 parameter settings (e.g.
  1922.         BM25Weight(1,0,1,0,0)) or custom weighting schemes.
  1923.  
  1924.         Parameters:
  1925.         -----------
  1926.  
  1927.         sort_key:  value number to sort on.
  1928.  
  1929.         reverse:  If true, reverses the sort order. (default true, but this
  1930.         default is confusing and deprecated in 1.1.0, so we recommend
  1931.         specifying this parameter explicitly). 
  1932.         """
  1933.         return _xapian.Enquire_set_sort_by_relevance_then_value(*args)
  1934.  
  1935.     def set_sort_by_key(*args):
  1936.         """
  1937.         Set the sorting to be by key generated from values only.
  1938.  
  1939.         void Xapian::Enquire::set_sort_by_key(Xapian::Sorter *sorter, bool
  1940.         reverse=true)
  1941.  
  1942.         Parameters:
  1943.         -----------
  1944.  
  1945.         sorter:  The functor to use for generating keys.
  1946.  
  1947.         reverse:  If true, reverses the sort order. (default true, but this
  1948.         default is confusing and deprecated in 1.1.0, so we recommend
  1949.         specifying this parameter explicitly). 
  1950.         """
  1951.         return _xapian.Enquire_set_sort_by_key(*args)
  1952.  
  1953.     def set_sort_by_key_then_relevance(*args):
  1954.         """
  1955.         Set the sorting to be by keys generated from values, then by relevance
  1956.         for documents with identical keys.
  1957.  
  1958.         void Xapian::Enquire::set_sort_by_key_then_relevance(Xapian::Sorter
  1959.         *sorter, bool reverse=true)
  1960.  
  1961.         Parameters:
  1962.         -----------
  1963.  
  1964.         sorter:  The functor to use for generating keys.
  1965.  
  1966.         reverse:  If true, reverses the sort order. (default true, but this
  1967.         default is confusing and deprecated in 1.1.0, so we recommend
  1968.         specifying this parameter explicitly). 
  1969.         """
  1970.         return _xapian.Enquire_set_sort_by_key_then_relevance(*args)
  1971.  
  1972.     def set_sort_by_relevance_then_key(*args):
  1973.         """
  1974.         Set the sorting to be by relevance, then by keys generated from
  1975.         values.
  1976.  
  1977.         void Xapian::Enquire::set_sort_by_relevance_then_key(Xapian::Sorter
  1978.         *sorter, bool reverse=true)
  1979.  
  1980.         Note that with the default BM25 weighting scheme parameters, non-
  1981.         identical documents will rarely have the same weight, so this setting
  1982.         will give very similar results to set_sort_by_relevance(). It becomes
  1983.         more useful with particular BM25 parameter settings (e.g.
  1984.         BM25Weight(1,0,1,0,0)) or custom weighting schemes.
  1985.  
  1986.         Parameters:
  1987.         -----------
  1988.  
  1989.         sorter:  The functor to use for generating keys.
  1990.  
  1991.         reverse:  If true, reverses the sort order. (default true, but this
  1992.         default is confusing and deprecated in 1.1.0, so we recommend
  1993.         specifying this parameter explicitly). 
  1994.         """
  1995.         return _xapian.Enquire_set_sort_by_relevance_then_key(*args)
  1996.  
  1997.     INCLUDE_QUERY_TERMS = _xapian.Enquire_INCLUDE_QUERY_TERMS
  1998.     USE_EXACT_TERMFREQ = _xapian.Enquire_USE_EXACT_TERMFREQ
  1999.     def get_mset(*args):
  2000.         """
  2001.         MSet
  2002.         Xapian::Enquire::get_mset(Xapian::doccount first, Xapian::doccount
  2003.         maxitems, const RSet *omrset, const MatchDecider *mdecider=0) const 
  2004.         """
  2005.         return _xapian.Enquire_get_mset(*args)
  2006.  
  2007.     def get_eset(*args):
  2008.         """
  2009.         Get the expand set for the given rset.
  2010.  
  2011.         ESet Xapian::Enquire::get_eset(Xapian::termcount maxitems, const RSet
  2012.         &omrset, const Xapian::ExpandDecider *edecider) const
  2013.  
  2014.         Parameters:
  2015.         -----------
  2016.  
  2017.         maxitems:  the maximum number of items to return.
  2018.  
  2019.         omrset:  the relevance set to use when performing the expand
  2020.         operation.
  2021.  
  2022.         edecider:  a decision functor to use to decide whether a given term
  2023.         should be put in the ESet
  2024.  
  2025.         An ESet object containing the results of the expand.
  2026.  
  2027.         Parameters:
  2028.         -----------
  2029.  
  2030.         Xapian::InvalidArgumentError:  See class documentation. 
  2031.         """
  2032.         return _xapian.Enquire_get_eset(*args)
  2033.  
  2034.     def get_matching_terms_begin(*args):
  2035.         """
  2036.         Get terms which match a given document, by match set item.
  2037.  
  2038.         TermIterator Xapian::Enquire::get_matching_terms_begin(const
  2039.         MSetIterator &it) const
  2040.  
  2041.         This method returns the terms in the current query which match the
  2042.         given document.
  2043.  
  2044.         If the underlying database has suitable support, using this call
  2045.         (rather than passing a Xapian::docid) will enable the system to ensure
  2046.         that the correct data is returned, and that the document has not been
  2047.         deleted or changed since the query was performed.
  2048.  
  2049.         Parameters:
  2050.         -----------
  2051.  
  2052.         it:  The iterator for which to retrieve the matching terms.
  2053.  
  2054.         An iterator returning the terms which match the document. The terms
  2055.         will be returned (as far as this makes any sense) in the same order as
  2056.         the terms in the query. Terms will not occur more than once, even if
  2057.         they do in the query.
  2058.  
  2059.         Parameters:
  2060.         -----------
  2061.  
  2062.         Xapian::InvalidArgumentError:  See class documentation.
  2063.  
  2064.         Xapian::DocNotFoundError:  The document specified could not be found
  2065.         in the database. 
  2066.         """
  2067.         return _xapian.Enquire_get_matching_terms_begin(*args)
  2068.  
  2069.     def get_matching_terms_end(*args):
  2070.         """
  2071.         End iterator corresponding to get_matching_terms_begin().
  2072.  
  2073.         TermIterator Xapian::Enquire::get_matching_terms_end(const
  2074.         MSetIterator &) const 
  2075.         """
  2076.         return _xapian.Enquire_get_matching_terms_end(*args)
  2077.  
  2078.     def __str__(*args):
  2079.         """
  2080.         Return a string describing this object.
  2081.  
  2082.         std::string Xapian::Enquire::get_description() const 
  2083.         """
  2084.         return _xapian.Enquire___str__(*args)
  2085.  
  2086.     def get_description(*args):
  2087.         """
  2088.         Return a string describing this object.
  2089.  
  2090.         std::string Xapian::Enquire::get_description() const 
  2091.         """
  2092.         return _xapian.Enquire_get_description(*args)
  2093.  
  2094. Enquire.set_query = new_instancemethod(_xapian.Enquire_set_query,None,Enquire)
  2095. Enquire.get_query = new_instancemethod(_xapian.Enquire_get_query,None,Enquire)
  2096. Enquire.set_weighting_scheme = new_instancemethod(_xapian.Enquire_set_weighting_scheme,None,Enquire)
  2097. Enquire.set_collapse_key = new_instancemethod(_xapian.Enquire_set_collapse_key,None,Enquire)
  2098. Enquire.set_docid_order = new_instancemethod(_xapian.Enquire_set_docid_order,None,Enquire)
  2099. Enquire.set_cutoff = new_instancemethod(_xapian.Enquire_set_cutoff,None,Enquire)
  2100. Enquire.set_sort_by_relevance = new_instancemethod(_xapian.Enquire_set_sort_by_relevance,None,Enquire)
  2101. Enquire.set_sort_by_value = new_instancemethod(_xapian.Enquire_set_sort_by_value,None,Enquire)
  2102. Enquire.set_sort_by_value_then_relevance = new_instancemethod(_xapian.Enquire_set_sort_by_value_then_relevance,None,Enquire)
  2103. Enquire.set_sort_by_relevance_then_value = new_instancemethod(_xapian.Enquire_set_sort_by_relevance_then_value,None,Enquire)
  2104. Enquire.set_sort_by_key = new_instancemethod(_xapian.Enquire_set_sort_by_key,None,Enquire)
  2105. Enquire.set_sort_by_key_then_relevance = new_instancemethod(_xapian.Enquire_set_sort_by_key_then_relevance,None,Enquire)
  2106. Enquire.set_sort_by_relevance_then_key = new_instancemethod(_xapian.Enquire_set_sort_by_relevance_then_key,None,Enquire)
  2107. Enquire.get_mset = new_instancemethod(_xapian.Enquire_get_mset,None,Enquire)
  2108. Enquire.get_eset = new_instancemethod(_xapian.Enquire_get_eset,None,Enquire)
  2109. Enquire.get_matching_terms_begin = new_instancemethod(_xapian.Enquire_get_matching_terms_begin,None,Enquire)
  2110. Enquire.get_matching_terms_end = new_instancemethod(_xapian.Enquire_get_matching_terms_end,None,Enquire)
  2111. Enquire.register_match_decider = new_instancemethod(_xapian.Enquire_register_match_decider,None,Enquire)
  2112. Enquire.get_matching_terms = new_instancemethod(_xapian.Enquire_get_matching_terms,None,Enquire)
  2113. Enquire.__str__ = new_instancemethod(_xapian.Enquire___str__,None,Enquire)
  2114. Enquire.get_description = new_instancemethod(_xapian.Enquire_get_description,None,Enquire)
  2115. Enquire_swigregister = _xapian.Enquire_swigregister
  2116. Enquire_swigregister(Enquire)
  2117.  
  2118. class Weight(object):
  2119.     """
  2120.     Abstract base class for weighting schemes. 
  2121.     """
  2122.     thisown = _swig_property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc='The membership flag')
  2123.     def __init__(self): raise AttributeError, "No constructor defined"
  2124.     __repr__ = _swig_repr
  2125.     __swig_destroy__ = _xapian.delete_Weight
  2126.     def name(*args):
  2127.         """
  2128.         Name of the weighting scheme.
  2129.  
  2130.         virtual std::string Xapian::Weight::name() const=0
  2131.  
  2132.         If the subclass is called FooWeight, this should return "Foo". 
  2133.         """
  2134.         return _xapian.Weight_name(*args)
  2135.  
  2136.     def serialise(*args):
  2137.         """
  2138.         Serialise object parameters into a string.
  2139.  
  2140.         virtual std::string Xapian::Weight::serialise() const=0 
  2141.         """
  2142.         return _xapian.Weight_serialise(*args)
  2143.  
  2144.     def unserialise(*args):
  2145.         """
  2146.         Create object given string serialisation returned by serialise().
  2147.  
  2148.         virtual Weight* Xapian::Weight::unserialise(const std::string &s)
  2149.         const=0 
  2150.         """
  2151.         return _xapian.Weight_unserialise(*args)
  2152.  
  2153.     def get_sumpart(*args):
  2154.         """
  2155.         Get a weight which is part of the sum over terms being performed.
  2156.  
  2157.         virtual Xapian::weight Xapian::Weight::get_sumpart(Xapian::termcount
  2158.         wdf, Xapian::doclength len) const=0
  2159.  
  2160.         This returns a weight for a given term and document. These weights are
  2161.         summed to give a total weight for the document.
  2162.  
  2163.         Parameters:
  2164.         -----------
  2165.  
  2166.         wdf:  the within document frequency of the term.
  2167.  
  2168.         len:  the (unnormalised) document length. 
  2169.         """
  2170.         return _xapian.Weight_get_sumpart(*args)
  2171.  
  2172.     def get_maxpart(*args):
  2173.         """
  2174.         Gets the maximum value that get_sumpart() may return.
  2175.  
  2176.         virtual Xapian::weight Xapian::Weight::get_maxpart() const=0
  2177.  
  2178.         This is used in optimising searches, by having the postlist tree decay
  2179.         appropriately when parts of it can have limited, or no, further
  2180.         effect. 
  2181.         """
  2182.         return _xapian.Weight_get_maxpart(*args)
  2183.  
  2184.     def get_sumextra(*args):
  2185.         """
  2186.         Get an extra weight for a document to add to the sum calculated over
  2187.         the query terms.
  2188.  
  2189.         virtual Xapian::weight Xapian::Weight::get_sumextra(Xapian::doclength
  2190.         len) const=0
  2191.  
  2192.         This returns a weight for a given document, and is used by some
  2193.         weighting schemes to account for influence such as document length.
  2194.  
  2195.         Parameters:
  2196.         -----------
  2197.  
  2198.         len:  the (unnormalised) document length. 
  2199.         """
  2200.         return _xapian.Weight_get_sumextra(*args)
  2201.  
  2202.     def get_maxextra(*args):
  2203.         """
  2204.         Gets the maximum value that get_sumextra() may return.
  2205.  
  2206.         virtual Xapian::weight Xapian::Weight::get_maxextra() const=0
  2207.  
  2208.         This is used in optimising searches. 
  2209.         """
  2210.         return _xapian.Weight_get_maxextra(*args)
  2211.  
  2212.     def get_sumpart_needs_doclength(*args):
  2213.         """
  2214.         return false if the weight object doesn't need doclength
  2215.  
  2216.         virtual bool Xapian::Weight::get_sumpart_needs_doclength() const 
  2217.         """
  2218.         return _xapian.Weight_get_sumpart_needs_doclength(*args)
  2219.  
  2220. Weight.name = new_instancemethod(_xapian.Weight_name,None,Weight)
  2221. Weight.serialise = new_instancemethod(_xapian.Weight_serialise,None,Weight)
  2222. Weight.unserialise = new_instancemethod(_xapian.Weight_unserialise,None,Weight)
  2223. Weight.get_sumpart = new_instancemethod(_xapian.Weight_get_sumpart,None,Weight)
  2224. Weight.get_maxpart = new_instancemethod(_xapian.Weight_get_maxpart,None,Weight)
  2225. Weight.get_sumextra = new_instancemethod(_xapian.Weight_get_sumextra,None,Weight)
  2226. Weight.get_maxextra = new_instancemethod(_xapian.Weight_get_maxextra,None,Weight)
  2227. Weight.get_sumpart_needs_doclength = new_instancemethod(_xapian.Weight_get_sumpart_needs_doclength,None,Weight)
  2228. Weight_swigregister = _xapian.Weight_swigregister
  2229. Weight_swigregister(Weight)
  2230.  
  2231. class BoolWeight(Weight):
  2232.     """
  2233.     Boolean weighting scheme (everything gets 0). 
  2234.     """
  2235.     thisown = _swig_property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc='The membership flag')
  2236.     __repr__ = _swig_repr
  2237.     def clone(*args):
  2238.         """
  2239.         Return a new weight object of this type.
  2240.  
  2241.         BoolWeight* Xapian::BoolWeight::clone() const
  2242.  
  2243.         A subclass called FooWeight taking parameters param1 and param2 should
  2244.         implement this as:
  2245.  
  2246.         virtual FooWeight * clone() const { return new FooWeight(param1,
  2247.         param2); } 
  2248.         """
  2249.         return _xapian.BoolWeight_clone(*args)
  2250.  
  2251.     def __init__(self, *args): 
  2252.         """Xapian::BoolWeight::BoolWeight() """
  2253.         _xapian.BoolWeight_swiginit(self,_xapian.new_BoolWeight(*args))
  2254.     __swig_destroy__ = _xapian.delete_BoolWeight
  2255.     def unserialise(*args):
  2256.         """
  2257.         Create object given string serialisation returned by serialise().
  2258.  
  2259.         BoolWeight* Xapian::BoolWeight::unserialise(const std::string &s)
  2260.         const 
  2261.         """
  2262.         return _xapian.BoolWeight_unserialise(*args)
  2263.  
  2264. BoolWeight.clone = new_instancemethod(_xapian.BoolWeight_clone,None,BoolWeight)
  2265. BoolWeight.unserialise = new_instancemethod(_xapian.BoolWeight_unserialise,None,BoolWeight)
  2266. BoolWeight_swigregister = _xapian.BoolWeight_swigregister
  2267. BoolWeight_swigregister(BoolWeight)
  2268.  
  2269. class BM25Weight(Weight):
  2270.     """
  2271.     BM25 weighting scheme.
  2272.  
  2273.     BM25 weighting options : The BM25 formula is \\[
  2274.     \\frac{k_{2}.n_{q}}{1+L_{d}}+\\sum_{t}\\frac{(k_{3}+1)q_{t
  2275.     }}{k_{3}+q_{t}}.\\frac{(k_{1}+1)f_{t,d}}{k_{1}((1-b)+bL_{d})+f_{t,d}
  2276.     }.w_{t} \\] where  $w_{t}$ is the termweight of term t
  2277.  
  2278.     $f_{t,d}$ is the within document frequency of term t in document d
  2279.  
  2280.     $q_{t}$ is the within query frequency of term t
  2281.  
  2282.     $L_{d}$ is the normalised length of document d
  2283.  
  2284.     $n_{q}$ is the size of the query
  2285.  
  2286.     $k_{1}$, $k_{2}$, $k_{3}$ and $b$ are user specified parameters 
  2287.     """
  2288.     thisown = _swig_property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc='The membership flag')
  2289.     __repr__ = _swig_repr
  2290.     def __init__(self, *args): 
  2291.         """Xapian::BM25Weight::BM25Weight() """
  2292.         _xapian.BM25Weight_swiginit(self,_xapian.new_BM25Weight(*args))
  2293.     def clone(*args):
  2294.         """
  2295.         Return a new weight object of this type.
  2296.  
  2297.         BM25Weight* Xapian::BM25Weight::clone() const
  2298.  
  2299.         A subclass called FooWeight taking parameters param1 and param2 should
  2300.         implement this as:
  2301.  
  2302.         virtual FooWeight * clone() const { return new FooWeight(param1,
  2303.         param2); } 
  2304.         """
  2305.         return _xapian.BM25Weight_clone(*args)
  2306.  
  2307.     __swig_destroy__ = _xapian.delete_BM25Weight
  2308.     def unserialise(*args):
  2309.         """
  2310.         Create object given string serialisation returned by serialise().
  2311.  
  2312.         BM25Weight* Xapian::BM25Weight::unserialise(const std::string &s)
  2313.         const 
  2314.         """
  2315.         return _xapian.BM25Weight_unserialise(*args)
  2316.  
  2317. BM25Weight.clone = new_instancemethod(_xapian.BM25Weight_clone,None,BM25Weight)
  2318. BM25Weight.unserialise = new_instancemethod(_xapian.BM25Weight_unserialise,None,BM25Weight)
  2319. BM25Weight_swigregister = _xapian.BM25Weight_swigregister
  2320. BM25Weight_swigregister(BM25Weight)
  2321.  
  2322. class TradWeight(Weight):
  2323.     """
  2324.     Traditional probabilistic weighting scheme.
  2325.  
  2326.     This class implements the Traditional Probabilistic Weighting scheme,
  2327.     as described by the early papers on Probabilistic Retrieval. BM25
  2328.     generally gives better results.
  2329.  
  2330.     The Traditional weighting scheme formula is \\[
  2331.     \\sum_{t}\\frac{f_{t,d}}{k.L_{d}+f_{t,d}}.w_{t} \\] where
  2332.     $w_{t}$ is the termweight of term t
  2333.  
  2334.     $f_{t,d}$ is the within document frequency of term t in document d
  2335.  
  2336.     $L_{d}$ is the normalised length of document d
  2337.  
  2338.     $k$ is a user specifiable parameter
  2339.  
  2340.     TradWeight(k) is equivalent to BM25Weight(k, 0, 0, 1, 0), except that
  2341.     the latter returns weights (k+1) times larger. 
  2342.     """
  2343.     thisown = _swig_property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc='The membership flag')
  2344.     __repr__ = _swig_repr
  2345.     def __init__(self, *args): 
  2346.         """Xapian::TradWeight::TradWeight() """
  2347.         _xapian.TradWeight_swiginit(self,_xapian.new_TradWeight(*args))
  2348.     def clone(*args):
  2349.         """
  2350.         Return a new weight object of this type.
  2351.  
  2352.         TradWeight* Xapian::TradWeight::clone() const
  2353.  
  2354.         A subclass called FooWeight taking parameters param1 and param2 should
  2355.         implement this as:
  2356.  
  2357.         virtual FooWeight * clone() const { return new FooWeight(param1,
  2358.         param2); } 
  2359.         """
  2360.         return _xapian.TradWeight_clone(*args)
  2361.  
  2362.     __swig_destroy__ = _xapian.delete_TradWeight
  2363.     def unserialise(*args):
  2364.         """
  2365.         Create object given string serialisation returned by serialise().
  2366.  
  2367.         TradWeight* Xapian::TradWeight::unserialise(const std::string &s)
  2368.         const 
  2369.         """
  2370.         return _xapian.TradWeight_unserialise(*args)
  2371.  
  2372. TradWeight.clone = new_instancemethod(_xapian.TradWeight_clone,None,TradWeight)
  2373. TradWeight.unserialise = new_instancemethod(_xapian.TradWeight_unserialise,None,TradWeight)
  2374. TradWeight_swigregister = _xapian.TradWeight_swigregister
  2375. TradWeight_swigregister(TradWeight)
  2376.  
  2377. class Database(object):
  2378.     """
  2379.     This class is used to access a database, or a group of databases.
  2380.  
  2381.     For searching, this class is used in conjunction with an Enquire
  2382.     object.
  2383.  
  2384.     Parameters:
  2385.     -----------
  2386.  
  2387.     InvalidArgumentError:  will be thrown if an invalid argument is
  2388.     supplied, for example, an unknown database type.
  2389.  
  2390.     DatabaseOpeningError:  may be thrown if the database cannot be opened
  2391.     (for example, a required file cannot be found).
  2392.  
  2393.     DatabaseVersionError:  may be thrown if the database is in an
  2394.     unsupported format (for example, created by a newer version of Xapian
  2395.     which uses an incompatible format). 
  2396.     """
  2397.     thisown = _swig_property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc='The membership flag')
  2398.     __repr__ = _swig_repr
  2399.     def add_database(*args):
  2400.         """
  2401.         Add an existing database (or group of databases) to those accessed by
  2402.         this object.
  2403.  
  2404.         void Xapian::Database::add_database(const Database &database)
  2405.  
  2406.         Parameters:
  2407.         -----------
  2408.  
  2409.         database:  the database(s) to add. 
  2410.         """
  2411.         return _xapian.Database_add_database(*args)
  2412.  
  2413.     __swig_destroy__ = _xapian.delete_Database
  2414.     def __init__(self, *args): 
  2415.         """
  2416.         Copying is allowed.
  2417.  
  2418.         Xapian::Database::Database(const Database &other)
  2419.  
  2420.         The internals are reference counted, so copying is cheap. 
  2421.         """
  2422.         _xapian.Database_swiginit(self,_xapian.new_Database(*args))
  2423.     def reopen(*args):
  2424.         """
  2425.         Re-open the database.
  2426.  
  2427.         void Xapian::Database::reopen()
  2428.  
  2429.         This re-opens the database(s) to the latest available version(s). It
  2430.         can be used either to make sure the latest results are returned, or to
  2431.         recover from a Xapian::DatabaseModifiedError. 
  2432.         """
  2433.         return _xapian.Database_reopen(*args)
  2434.  
  2435.     def __str__(*args):
  2436.         """
  2437.         Return a string describing this object.
  2438.  
  2439.         virtual std::string Xapian::Database::get_description() const 
  2440.         """
  2441.         return _xapian.Database___str__(*args)
  2442.  
  2443.     def postlist_begin(*args):
  2444.         """
  2445.         An iterator pointing to the start of the postlist for a given term.
  2446.  
  2447.         PostingIterator Xapian::Database::postlist_begin(const std::string
  2448.         &tname) const
  2449.  
  2450.         If the term name is the empty string, the iterator returned will list
  2451.         all the documents in the database. Such an iterator will always return
  2452.         a WDF value of 1, since there is no obvious meaning for this quantity
  2453.         in this case. 
  2454.         """
  2455.         return _xapian.Database_postlist_begin(*args)
  2456.  
  2457.     def postlist_end(*args):
  2458.         """
  2459.         Corresponding end iterator to postlist_begin().
  2460.  
  2461.         PostingIterator Xapian::Database::postlist_end(const std::string &)
  2462.         const 
  2463.         """
  2464.         return _xapian.Database_postlist_end(*args)
  2465.  
  2466.     def termlist_begin(*args):
  2467.         """
  2468.         An iterator pointing to the start of the termlist for a given
  2469.         document.
  2470.  
  2471.         TermIterator Xapian::Database::termlist_begin(Xapian::docid did) const
  2472.  
  2473.         """
  2474.         return _xapian.Database_termlist_begin(*args)
  2475.  
  2476.     def termlist_end(*args):
  2477.         """
  2478.         Corresponding end iterator to termlist_begin().
  2479.  
  2480.         TermIterator Xapian::Database::termlist_end(Xapian::docid) const 
  2481.         """
  2482.         return _xapian.Database_termlist_end(*args)
  2483.  
  2484.     def positionlist_begin(*args):
  2485.         """
  2486.         An iterator pointing to the start of the position list for a given
  2487.         term in a given document.
  2488.  
  2489.         PositionIterator Xapian::Database::positionlist_begin(Xapian::docid
  2490.         did, const std::string &tname) const 
  2491.         """
  2492.         return _xapian.Database_positionlist_begin(*args)
  2493.  
  2494.     def positionlist_end(*args):
  2495.         """
  2496.         Corresponding end iterator to positionlist_begin().
  2497.  
  2498.         PositionIterator Xapian::Database::positionlist_end(Xapian::docid,
  2499.         const std::string &) const 
  2500.         """
  2501.         return _xapian.Database_positionlist_end(*args)
  2502.  
  2503.     def allterms_begin(*args):
  2504.         """
  2505.         An iterator which runs across all terms with a given prefix.
  2506.  
  2507.         TermIterator Xapian::Database::allterms_begin(const std::string
  2508.         &prefix) const
  2509.  
  2510.         This is functionally similar to getting an iterator with
  2511.         allterms_begin() and then calling skip_to(prefix) on that iterator to
  2512.         move to the start of the prefix, but is more convenient (because it
  2513.         detects the end of the prefixed terms), and may be more efficient than
  2514.         simply calling skip_to() after opening the iterator, particularly for
  2515.         network databases.
  2516.  
  2517.         Parameters:
  2518.         -----------
  2519.  
  2520.         prefix:  The prefix to restrict the returned terms to. 
  2521.         """
  2522.         return _xapian.Database_allterms_begin(*args)
  2523.  
  2524.     def allterms_end(*args):
  2525.         """
  2526.         Corresponding end iterator to allterms_begin(prefix).
  2527.  
  2528.         TermIterator Xapian::Database::allterms_end(const std::string &) const
  2529.  
  2530.         """
  2531.         return _xapian.Database_allterms_end(*args)
  2532.  
  2533.     def get_doccount(*args):
  2534.         """
  2535.         Get the number of documents in the database.
  2536.  
  2537.         Xapian::doccount Xapian::Database::get_doccount() const 
  2538.         """
  2539.         return _xapian.Database_get_doccount(*args)
  2540.  
  2541.     def get_lastdocid(*args):
  2542.         """
  2543.         Get the highest document id which has been used in the database.
  2544.  
  2545.         Xapian::docid Xapian::Database::get_lastdocid() const 
  2546.         """
  2547.         return _xapian.Database_get_lastdocid(*args)
  2548.  
  2549.     def get_avlength(*args):
  2550.         """
  2551.         Get the average length of the documents in the database.
  2552.  
  2553.         Xapian::doclength Xapian::Database::get_avlength() const 
  2554.         """
  2555.         return _xapian.Database_get_avlength(*args)
  2556.  
  2557.     def get_termfreq(*args):
  2558.         """
  2559.         Get the number of documents in the database indexed by a given term.
  2560.  
  2561.         Xapian::doccount Xapian::Database::get_termfreq(const std::string
  2562.         &tname) const 
  2563.         """
  2564.         return _xapian.Database_get_termfreq(*args)
  2565.  
  2566.     def term_exists(*args):
  2567.         """
  2568.         Check if a given term exists in the database.
  2569.  
  2570.         bool Xapian::Database::term_exists(const std::string &tname) const
  2571.  
  2572.         Return true if and only if the term exists in the database. This is
  2573.         the same as (get_termfreq(tname) != 0), but will often be more
  2574.         efficient. 
  2575.         """
  2576.         return _xapian.Database_term_exists(*args)
  2577.  
  2578.     def get_collection_freq(*args):
  2579.         """
  2580.         Return the total number of occurrences of the given term.
  2581.  
  2582.         Xapian::termcount Xapian::Database::get_collection_freq(const
  2583.         std::string &tname) const
  2584.  
  2585.         This is the sum of the number of occurrences of the term in each
  2586.         document it indexes: i.e., the sum of the within document frequencies
  2587.         of the term.
  2588.  
  2589.         Parameters:
  2590.         -----------
  2591.  
  2592.         tname:  The term whose collection frequency is being requested. 
  2593.         """
  2594.         return _xapian.Database_get_collection_freq(*args)
  2595.  
  2596.     def get_doclength(*args):
  2597.         """
  2598.         Get the length of a document.
  2599.  
  2600.         Xapian::doclength Xapian::Database::get_doclength(Xapian::docid did)
  2601.         const 
  2602.         """
  2603.         return _xapian.Database_get_doclength(*args)
  2604.  
  2605.     def keep_alive(*args):
  2606.         """
  2607.         Send a "keep-alive" to remote databases to stop them timing out.
  2608.  
  2609.         void Xapian::Database::keep_alive() 
  2610.         """
  2611.         return _xapian.Database_keep_alive(*args)
  2612.  
  2613.     def get_document(*args):
  2614.         """
  2615.         Get a document from the database, given its document id.
  2616.  
  2617.         Xapian::Document Xapian::Database::get_document(Xapian::docid did)
  2618.         const
  2619.  
  2620.         This method returns a Xapian::Document object which provides the
  2621.         information about a document.
  2622.  
  2623.         Parameters:
  2624.         -----------
  2625.  
  2626.         did:  The document id for which to retrieve the data.
  2627.  
  2628.         A Xapian::Document object containing the document data
  2629.  
  2630.         Parameters:
  2631.         -----------
  2632.  
  2633.         Xapian::DocNotFoundError:  The document specified could not be found
  2634.         in the database. 
  2635.         """
  2636.         return _xapian.Database_get_document(*args)
  2637.  
  2638.     def get_spelling_suggestion(*args):
  2639.         """
  2640.         Suggest a spelling correction.
  2641.  
  2642.         std::string Xapian::Database::get_spelling_suggestion(const
  2643.         std::string &word, unsigned max_edit_distance=2) const
  2644.  
  2645.         Parameters:
  2646.         -----------
  2647.  
  2648.         word:  The potentially misspelled word.
  2649.  
  2650.         max_edit_distance:  Only consider words which are at most
  2651.         max_edit_distance edits from word. An edit is a character insertion,
  2652.         deletion, or the transposition of two adjacent characters (default is
  2653.         2). 
  2654.         """
  2655.         return _xapian.Database_get_spelling_suggestion(*args)
  2656.  
  2657.     def spellings_begin(*args):
  2658.         """
  2659.         An iterator which returns all the spelling correction targets.
  2660.  
  2661.         Xapian::TermIterator Xapian::Database::spellings_begin() const
  2662.  
  2663.         This returns all the words which are considered as targets for the
  2664.         spelling correction algorithm. The frequency of each word is available
  2665.         as the term frequency of each entry in the returned iterator. 
  2666.         """
  2667.         return _xapian.Database_spellings_begin(*args)
  2668.  
  2669.     def spellings_end(*args):
  2670.         """
  2671.         Corresponding end iterator to spellings_begin().
  2672.  
  2673.         Xapian::TermIterator Xapian::Database::spellings_end() const 
  2674.         """
  2675.         return _xapian.Database_spellings_end(*args)
  2676.  
  2677.     def synonyms_begin(*args):
  2678.         """
  2679.         An iterator which returns all the synonyms for a given term.
  2680.  
  2681.         Xapian::TermIterator Xapian::Database::synonyms_begin(const
  2682.         std::string &term) const
  2683.  
  2684.         Parameters:
  2685.         -----------
  2686.  
  2687.         term:  The term to return synonyms for. 
  2688.         """
  2689.         return _xapian.Database_synonyms_begin(*args)
  2690.  
  2691.     def synonyms_end(*args):
  2692.         """
  2693.         Corresponding end iterator to synonyms_begin(term).
  2694.  
  2695.         Xapian::TermIterator Xapian::Database::synonyms_end(const std::string
  2696.         &) const 
  2697.         """
  2698.         return _xapian.Database_synonyms_end(*args)
  2699.  
  2700.     def synonym_keys_begin(*args):
  2701.         """
  2702.         An iterator which returns all terms which have synonyms.
  2703.  
  2704.         Xapian::TermIterator Xapian::Database::synonym_keys_begin(const
  2705.         std::string &prefix="") const
  2706.  
  2707.         Parameters:
  2708.         -----------
  2709.  
  2710.         prefix:  If non-empty, only terms with this prefix are returned. 
  2711.         """
  2712.         return _xapian.Database_synonym_keys_begin(*args)
  2713.  
  2714.     def synonym_keys_end(*args):
  2715.         """
  2716.         Corresponding end iterator to synonym_keys_begin(prefix).
  2717.  
  2718.         Xapian::TermIterator Xapian::Database::synonym_keys_end(const
  2719.         std::string &="") const 
  2720.         """
  2721.         return _xapian.Database_synonym_keys_end(*args)
  2722.  
  2723.     def get_metadata(*args):
  2724.         """
  2725.         Get the user-specified metadata associated with a given key.
  2726.  
  2727.         std::string Xapian::Database::get_metadata(const std::string &key)
  2728.         const
  2729.  
  2730.         User-specified metadata allows you to store arbitrary information in
  2731.         the form of (key,tag) pairs. See  WritableDatabase::set_metadata() for
  2732.         more information.
  2733.  
  2734.         When invoked on a Xapian::Database object representing multiple
  2735.         databases, currently only the metadata for the first is considered but
  2736.         this behaviour may change in the future.
  2737.  
  2738.         If there is no piece of metadata associated with the specified key, an
  2739.         empty string is returned (this applies even for backends which don't
  2740.         support metadata).
  2741.  
  2742.         Empty keys are not valid, and specifying one will cause an exception.
  2743.  
  2744.         Parameters:
  2745.         -----------
  2746.  
  2747.         key:  The key of the metadata item to access.
  2748.  
  2749.         The retrieved metadata item's value.
  2750.  
  2751.         Parameters:
  2752.         -----------
  2753.  
  2754.         Xapian::InvalidArgumentError:  will be thrown if the key supplied is
  2755.         empty. 
  2756.         """
  2757.         return _xapian.Database_get_metadata(*args)
  2758.  
  2759.     def _metadata_keys_begin(*args):
  2760.         """
  2761.         An iterator which returns all user-specified metadata keys.
  2762.  
  2763.         Xapian::TermIterator Xapian::Database::metadata_keys_begin(const
  2764.         std::string &prefix="") const
  2765.  
  2766.         When invoked on a Xapian::Database object representing multiple
  2767.         databases, currently only the metadata for the first is considered but
  2768.         this behaviour may change in the future.
  2769.  
  2770.         If the backend doesn't support metadata, then this method returns an
  2771.         iterator which compares equal to that returned by metadata_keys_end().
  2772.  
  2773.         Parameters:
  2774.         -----------
  2775.  
  2776.         prefix:  If non-empty, only keys with this prefix are returned.
  2777.  
  2778.         Parameters:
  2779.         -----------
  2780.  
  2781.         Xapian::UnimplementedError:  will be thrown if the backend implements
  2782.         user-specified metadata, but doesn't implement iterating its keys
  2783.         (currently this happens for the InMemory backend). 
  2784.         """
  2785.         return _xapian.Database__metadata_keys_begin(*args)
  2786.  
  2787.     def _metadata_keys_end(*args):
  2788.         """
  2789.         Corresponding end iterator to metadata_keys_begin().
  2790.  
  2791.         Xapian::TermIterator Xapian::Database::metadata_keys_end(const
  2792.         std::string &="") const 
  2793.         """
  2794.         return _xapian.Database__metadata_keys_end(*args)
  2795.  
  2796.     def get_description(*args):
  2797.         """
  2798.         Return a string describing this object.
  2799.  
  2800.         virtual std::string Xapian::Database::get_description() const 
  2801.         """
  2802.         return _xapian.Database_get_description(*args)
  2803.  
  2804. Database.add_database = new_instancemethod(_xapian.Database_add_database,None,Database)
  2805. Database.reopen = new_instancemethod(_xapian.Database_reopen,None,Database)
  2806. Database.__str__ = new_instancemethod(_xapian.Database___str__,None,Database)
  2807. Database.postlist_begin = new_instancemethod(_xapian.Database_postlist_begin,None,Database)
  2808. Database.postlist_end = new_instancemethod(_xapian.Database_postlist_end,None,Database)
  2809. Database.termlist_begin = new_instancemethod(_xapian.Database_termlist_begin,None,Database)
  2810. Database.termlist_end = new_instancemethod(_xapian.Database_termlist_end,None,Database)
  2811. Database.positionlist_begin = new_instancemethod(_xapian.Database_positionlist_begin,None,Database)
  2812. Database.positionlist_end = new_instancemethod(_xapian.Database_positionlist_end,None,Database)
  2813. Database.allterms_begin = new_instancemethod(_xapian.Database_allterms_begin,None,Database)
  2814. Database.allterms_end = new_instancemethod(_xapian.Database_allterms_end,None,Database)
  2815. Database.get_doccount = new_instancemethod(_xapian.Database_get_doccount,None,Database)
  2816. Database.get_lastdocid = new_instancemethod(_xapian.Database_get_lastdocid,None,Database)
  2817. Database.get_avlength = new_instancemethod(_xapian.Database_get_avlength,None,Database)
  2818. Database.get_termfreq = new_instancemethod(_xapian.Database_get_termfreq,None,Database)
  2819. Database.term_exists = new_instancemethod(_xapian.Database_term_exists,None,Database)
  2820. Database.get_collection_freq = new_instancemethod(_xapian.Database_get_collection_freq,None,Database)
  2821. Database.get_doclength = new_instancemethod(_xapian.Database_get_doclength,None,Database)
  2822. Database.keep_alive = new_instancemethod(_xapian.Database_keep_alive,None,Database)
  2823. Database.get_document = new_instancemethod(_xapian.Database_get_document,None,Database)
  2824. Database.get_spelling_suggestion = new_instancemethod(_xapian.Database_get_spelling_suggestion,None,Database)
  2825. Database.spellings_begin = new_instancemethod(_xapian.Database_spellings_begin,None,Database)
  2826. Database.spellings_end = new_instancemethod(_xapian.Database_spellings_end,None,Database)
  2827. Database.synonyms_begin = new_instancemethod(_xapian.Database_synonyms_begin,None,Database)
  2828. Database.synonyms_end = new_instancemethod(_xapian.Database_synonyms_end,None,Database)
  2829. Database.synonym_keys_begin = new_instancemethod(_xapian.Database_synonym_keys_begin,None,Database)
  2830. Database.synonym_keys_end = new_instancemethod(_xapian.Database_synonym_keys_end,None,Database)
  2831. Database.get_metadata = new_instancemethod(_xapian.Database_get_metadata,None,Database)
  2832. Database._metadata_keys_begin = new_instancemethod(_xapian.Database__metadata_keys_begin,None,Database)
  2833. Database._metadata_keys_end = new_instancemethod(_xapian.Database__metadata_keys_end,None,Database)
  2834. Database.get_description = new_instancemethod(_xapian.Database_get_description,None,Database)
  2835. Database_swigregister = _xapian.Database_swigregister
  2836. Database_swigregister(Database)
  2837.  
  2838. class WritableDatabase(Database):
  2839.     """
  2840.     This class provides read/write access to a database. 
  2841.     """
  2842.     thisown = _swig_property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc='The membership flag')
  2843.     __repr__ = _swig_repr
  2844.     __swig_destroy__ = _xapian.delete_WritableDatabase
  2845.     def __init__(self, *args): 
  2846.         """
  2847.         Copying is allowed.
  2848.  
  2849.         Xapian::WritableDatabase::WritableDatabase(const WritableDatabase
  2850.         &other)
  2851.  
  2852.         The internals are reference counted, so copying is cheap. 
  2853.         """
  2854.         _xapian.WritableDatabase_swiginit(self,_xapian.new_WritableDatabase(*args))
  2855.     def flush(*args):
  2856.         """
  2857.         Flush to disk any modifications made to the database.
  2858.  
  2859.         void Xapian::WritableDatabase::flush()
  2860.  
  2861.         For efficiency reasons, when performing multiple updates to a database
  2862.         it is best (indeed, almost essential) to make as many modifications as
  2863.         memory will permit in a single pass through the database. To ensure
  2864.         this, Xapian batches up modifications.
  2865.  
  2866.         Flush may be called at any time to ensure that the modifications which
  2867.         have been made are written to disk: if the flush succeeds, all the
  2868.         preceding modifications will have been written to disk.
  2869.  
  2870.         If any of the modifications fail, an exception will be thrown and the
  2871.         database will be left in a state in which each separate addition,
  2872.         replacement or deletion operation has either been fully performed or
  2873.         not performed at all: it is then up to the application to work out
  2874.         which operations need to be repeated.
  2875.  
  2876.         It's not valid to call flush within a transaction.
  2877.  
  2878.         Beware of calling flush too frequently: this will have a severe
  2879.         performance cost.
  2880.  
  2881.         Note that flush need not be called explicitly: it will be called
  2882.         automatically when the database is closed, or when a sufficient number
  2883.         of modifications have been made. By default, this is every 10000
  2884.         documents added, deleted, or modified. This value is rather
  2885.         conservative, and if you have a machine with plenty of memory, you can
  2886.         improve indexing throughput dramatically by setting
  2887.         XAPIAN_FLUSH_THRESHOLD in the environment to a larger value.
  2888.  
  2889.         Parameters:
  2890.         -----------
  2891.  
  2892.         Xapian::DatabaseError:  will be thrown if a problem occurs while
  2893.         modifying the database.
  2894.  
  2895.         Xapian::DatabaseCorruptError:  will be thrown if the database is in a
  2896.         corrupt state. 
  2897.         """
  2898.         return _xapian.WritableDatabase_flush(*args)
  2899.  
  2900.     def begin_transaction(*args):
  2901.         """
  2902.         Begin a transaction.
  2903.  
  2904.         void Xapian::WritableDatabase::begin_transaction(bool flushed=true)
  2905.  
  2906.         In Xapian a transaction is a group of modifications to the database
  2907.         which are linked such that either all will be applied simultaneously
  2908.         or none will be applied at all. Even in the case of a power failure,
  2909.         this characteristic should be preserved (as long as the filesystem
  2910.         isn't corrupted, etc).
  2911.  
  2912.         A transaction is started with begin_transaction() and can either be
  2913.         committed by calling commit_transaction() or aborted by calling
  2914.         cancel_transaction().
  2915.  
  2916.         By default, a transaction implicitly calls flush before and after so
  2917.         that the modifications stand and fall without affecting modifications
  2918.         before or after.
  2919.  
  2920.         The downside of this flushing is that small transactions cause
  2921.         modifications to be frequently flushed which can harm indexing
  2922.         performance in the same way that explicitly calling flush frequently
  2923.         can.
  2924.  
  2925.         If you're applying atomic groups of changes and only wish to ensure
  2926.         that each group is either applied or not applied, then you can prevent
  2927.         the automatic flush before and after the transaction by starting the
  2928.         transaction with begin_transaction(false). However, if
  2929.         cancel_transaction is called (or if commit_transaction isn't called
  2930.         before the WritableDatabase object is destroyed) then any changes
  2931.         which were pending before the transaction began will also be
  2932.         discarded.
  2933.  
  2934.         Transactions aren't currently supported by the InMemory backend.
  2935.  
  2936.         Parameters:
  2937.         -----------
  2938.  
  2939.         Xapian::UnimplementedError:  will be thrown if transactions are not
  2940.         available for this database type.
  2941.  
  2942.         Xapian::InvalidOperationError:  will be thrown if this is called at an
  2943.         invalid time, such as when a transaction is already in progress. 
  2944.         """
  2945.         return _xapian.WritableDatabase_begin_transaction(*args)
  2946.  
  2947.     def commit_transaction(*args):
  2948.         """
  2949.         Complete the transaction currently in progress.
  2950.  
  2951.         void Xapian::WritableDatabase::commit_transaction()
  2952.  
  2953.         If this method completes successfully and this is a flushed
  2954.         transaction, all the database modifications made during the
  2955.         transaction will have been committed to the database.
  2956.  
  2957.         If an error occurs, an exception will be thrown, and none of the
  2958.         modifications made to the database during the transaction will have
  2959.         been applied to the database.
  2960.  
  2961.         In all cases the transaction will no longer be in progress.
  2962.  
  2963.         Parameters:
  2964.         -----------
  2965.  
  2966.         Xapian::DatabaseError:  will be thrown if a problem occurs while
  2967.         modifying the database.
  2968.  
  2969.         Xapian::DatabaseCorruptError:  will be thrown if the database is in a
  2970.         corrupt state.
  2971.  
  2972.         Xapian::InvalidOperationError:  will be thrown if a transaction is not
  2973.         currently in progress.
  2974.  
  2975.         Xapian::UnimplementedError:  will be thrown if transactions are not
  2976.         available for this database type. 
  2977.         """
  2978.         return _xapian.WritableDatabase_commit_transaction(*args)
  2979.  
  2980.     def cancel_transaction(*args):
  2981.         """
  2982.         Abort the transaction currently in progress, discarding the potential
  2983.         modifications made to the database.
  2984.  
  2985.         void Xapian::WritableDatabase::cancel_transaction()
  2986.  
  2987.         If an error occurs in this method, an exception will be thrown, but
  2988.         the transaction will be cancelled anyway.
  2989.  
  2990.         Parameters:
  2991.         -----------
  2992.  
  2993.         Xapian::DatabaseError:  will be thrown if a problem occurs while
  2994.         modifying the database.
  2995.  
  2996.         Xapian::DatabaseCorruptError:  will be thrown if the database is in a
  2997.         corrupt state.
  2998.  
  2999.         Xapian::InvalidOperationError:  will be thrown if a transaction is not
  3000.         currently in progress.
  3001.  
  3002.         Xapian::UnimplementedError:  will be thrown if transactions are not
  3003.         available for this database type. 
  3004.         """
  3005.         return _xapian.WritableDatabase_cancel_transaction(*args)
  3006.  
  3007.     def add_document(*args):
  3008.         """
  3009.         Add a new document to the database.
  3010.  
  3011.         Xapian::docid Xapian::WritableDatabase::add_document(const
  3012.         Xapian::Document &document)
  3013.  
  3014.         This method adds the specified document to the database, returning a
  3015.         newly allocated document ID. Automatically allocated document IDs come
  3016.         from a per-database monotonically increasing counter, so IDs from
  3017.         deleted documents won't be reused.
  3018.  
  3019.         If you want to specify the document ID to be used, you should call
  3020.         replace_document() instead.
  3021.  
  3022.         Note that changes to the database won't be immediately committed to
  3023.         disk; see flush() for more details.
  3024.  
  3025.         As with all database modification operations, the effect is atomic:
  3026.         the document will either be fully added, or the document fails to be
  3027.         added and an exception is thrown (possibly at a later time when flush
  3028.         is called or the database is closed).
  3029.  
  3030.         Parameters:
  3031.         -----------
  3032.  
  3033.         document:  The new document to be added.
  3034.  
  3035.         The document ID of the newly added document.
  3036.  
  3037.         Parameters:
  3038.         -----------
  3039.  
  3040.         Xapian::DatabaseError:  will be thrown if a problem occurs while
  3041.         writing to the database.
  3042.  
  3043.         Xapian::DatabaseCorruptError:  will be thrown if the database is in a
  3044.         corrupt state. 
  3045.         """
  3046.         return _xapian.WritableDatabase_add_document(*args)
  3047.  
  3048.     def delete_document(*args):
  3049.         """
  3050.         Delete any documents indexed by a term from the database.
  3051.  
  3052.         void Xapian::WritableDatabase::delete_document(const std::string
  3053.         &unique_term)
  3054.  
  3055.         This method removes any documents indexed by the specified term from
  3056.         the database.
  3057.  
  3058.         A major use is for convenience when UIDs from another system are
  3059.         mapped to terms in Xapian, although this method has other uses (for
  3060.         example, you could add a "deletion date" term to documents at index
  3061.         time and use this method to delete all documents due for deletion on a
  3062.         particular date).
  3063.  
  3064.         Parameters:
  3065.         -----------
  3066.  
  3067.         unique_term:  The term to remove references to.
  3068.  
  3069.         Parameters:
  3070.         -----------
  3071.  
  3072.         Xapian::DatabaseError:  will be thrown if a problem occurs while
  3073.         writing to the database.
  3074.  
  3075.         Xapian::DatabaseCorruptError:  will be thrown if the database is in a
  3076.         corrupt state. 
  3077.         """
  3078.         return _xapian.WritableDatabase_delete_document(*args)
  3079.  
  3080.     def replace_document(*args):
  3081.         """
  3082.         Replace any documents matching a term.
  3083.  
  3084.         Xapian::docid Xapian::WritableDatabase::replace_document(const
  3085.         std::string &unique_term, const Xapian::Document &document)
  3086.  
  3087.         This method replaces any documents indexed by the specified term with
  3088.         the specified document. If any documents are indexed by the term, the
  3089.         lowest document ID will be used for the document, otherwise a new
  3090.         document ID will be generated as for add_document.
  3091.  
  3092.         A major use is for convenience when UIDs from another system are
  3093.         mapped to terms in Xapian, although this method has other uses (for
  3094.         example, you could add a "deletion date" term to documents at index
  3095.         time and use this method to delete all documents due for deletion on a
  3096.         particular date).
  3097.  
  3098.         Note that changes to the database won't be immediately committed to
  3099.         disk; see flush() for more details.
  3100.  
  3101.         As with all database modification operations, the effect is atomic:
  3102.         the document(s) will either be fully replaced, or the document(s) fail
  3103.         to be replaced and an exception is thrown (possibly at a later time
  3104.         when flush is called or the database is closed).
  3105.  
  3106.         Parameters:
  3107.         -----------
  3108.  
  3109.         unique_term:  The "unique" term.
  3110.  
  3111.         document:  The new document.
  3112.  
  3113.         The document ID that document was given.
  3114.  
  3115.         Parameters:
  3116.         -----------
  3117.  
  3118.         Xapian::DatabaseError:  will be thrown if a problem occurs while
  3119.         writing to the database.
  3120.  
  3121.         Xapian::DatabaseCorruptError:  will be thrown if the database is in a
  3122.         corrupt state. 
  3123.         """
  3124.         return _xapian.WritableDatabase_replace_document(*args)
  3125.  
  3126.     def add_spelling(*args):
  3127.         """
  3128.         Add a word to the spelling dictionary.
  3129.  
  3130.         void Xapian::WritableDatabase::add_spelling(const std::string &word,
  3131.         Xapian::termcount freqinc=1) const
  3132.  
  3133.         If the word is already present, its frequency is increased.
  3134.  
  3135.         Parameters:
  3136.         -----------
  3137.  
  3138.         word:  The word to add.
  3139.  
  3140.         freqinc:  How much to increase its frequency by (default 1). 
  3141.         """
  3142.         return _xapian.WritableDatabase_add_spelling(*args)
  3143.  
  3144.     def remove_spelling(*args):
  3145.         """
  3146.         Remove a word from the spelling dictionary.
  3147.  
  3148.         void Xapian::WritableDatabase::remove_spelling(const std::string
  3149.         &word, Xapian::termcount freqdec=1) const
  3150.  
  3151.         The word's frequency is decreased, and if would become zero or less
  3152.         then the word is removed completely.
  3153.  
  3154.         Parameters:
  3155.         -----------
  3156.  
  3157.         word:  The word to remove.
  3158.  
  3159.         freqdec:  How much to decrease its frequency by (default 1). 
  3160.         """
  3161.         return _xapian.WritableDatabase_remove_spelling(*args)
  3162.  
  3163.     def add_synonym(*args):
  3164.         """
  3165.         Add a synonym for a term.
  3166.  
  3167.         void Xapian::WritableDatabase::add_synonym(const std::string &term,
  3168.         const std::string &synonym) const
  3169.  
  3170.         If synonym is already a synonym for term, then no action is taken. 
  3171.         """
  3172.         return _xapian.WritableDatabase_add_synonym(*args)
  3173.  
  3174.     def remove_synonym(*args):
  3175.         """
  3176.         Remove a synonym for a term.
  3177.  
  3178.         void Xapian::WritableDatabase::remove_synonym(const std::string &term,
  3179.         const std::string &synonym) const
  3180.  
  3181.         If synonym isn't a synonym for term, then no action is taken. 
  3182.         """
  3183.         return _xapian.WritableDatabase_remove_synonym(*args)
  3184.  
  3185.     def clear_synonyms(*args):
  3186.         """
  3187.         Remove all synonyms for a term.
  3188.  
  3189.         void Xapian::WritableDatabase::clear_synonyms(const std::string &term)
  3190.         const
  3191.  
  3192.         If term has no synonyms, no action is taken. 
  3193.         """
  3194.         return _xapian.WritableDatabase_clear_synonyms(*args)
  3195.  
  3196.     def set_metadata(*args):
  3197.         """
  3198.         Set the user-specified metadata associated with a given key.
  3199.  
  3200.         void Xapian::WritableDatabase::set_metadata(const std::string &key,
  3201.         const std::string &value)
  3202.  
  3203.         This method sets the metadata value associated with a given key. If
  3204.         there is already a metadata value stored in the database with the same
  3205.         key, the old value is replaced. If you want to delete an existing item
  3206.         of metadata, just set its value to the empty string.
  3207.  
  3208.         User-specified metadata allows you to store arbitrary information in
  3209.         the form of (key,tag) pairs.
  3210.  
  3211.         There's no hard limit on the number of metadata items, or the size of
  3212.         the metadata values. Metadata keys have a limited length, which
  3213.         depends on the backend. We recommend limiting them to 200 bytes. Empty
  3214.         keys are not valid, and specifying one will cause an exception.
  3215.  
  3216.         Metadata modifications are committed to disk in the same way as
  3217.         modifications to the documents in the database are: i.e.,
  3218.         modifications are atomic, and won't be committed to disk immediately
  3219.         (see flush() for more details). This allows metadata to be used to
  3220.         link databases with versioned external resources by storing the
  3221.         appropriate version number in a metadata item.
  3222.  
  3223.         You can also use the metadata to store arbitrary extra information
  3224.         associated with terms, documents, or postings by encoding the termname
  3225.         and/or document id into the metadata key.
  3226.  
  3227.         Parameters:
  3228.         -----------
  3229.  
  3230.         key:  The key of the metadata item to set.
  3231.  
  3232.         value:  The value of the metadata item to set.
  3233.  
  3234.         Parameters:
  3235.         -----------
  3236.  
  3237.         Xapian::DatabaseError:  will be thrown if a problem occurs while
  3238.         writing to the database.
  3239.  
  3240.         Xapian::DatabaseCorruptError:  will be thrown if the database is in a
  3241.         corrupt state.
  3242.  
  3243.         Xapian::InvalidArgumentError:  will be thrown if the key supplied is
  3244.         empty.
  3245.  
  3246.         Xapian::UnimplementedError:  will be thrown if the database backend in
  3247.         use doesn't support user- specified metadata. 
  3248.         """
  3249.         return _xapian.WritableDatabase_set_metadata(*args)
  3250.  
  3251.     def __str__(*args):
  3252.         """
  3253.         Return a string describing this object.
  3254.  
  3255.         std::string Xapian::WritableDatabase::get_description() const 
  3256.         """
  3257.         return _xapian.WritableDatabase___str__(*args)
  3258.  
  3259.     def get_description(*args):
  3260.         """
  3261.         Return a string describing this object.
  3262.  
  3263.         std::string Xapian::WritableDatabase::get_description() const 
  3264.         """
  3265.         return _xapian.WritableDatabase_get_description(*args)
  3266.  
  3267. WritableDatabase.flush = new_instancemethod(_xapian.WritableDatabase_flush,None,WritableDatabase)
  3268. WritableDatabase.begin_transaction = new_instancemethod(_xapian.WritableDatabase_begin_transaction,None,WritableDatabase)
  3269. WritableDatabase.commit_transaction = new_instancemethod(_xapian.WritableDatabase_commit_transaction,None,WritableDatabase)
  3270. WritableDatabase.cancel_transaction = new_instancemethod(_xapian.WritableDatabase_cancel_transaction,None,WritableDatabase)
  3271. WritableDatabase.add_document = new_instancemethod(_xapian.WritableDatabase_add_document,None,WritableDatabase)
  3272. WritableDatabase.delete_document = new_instancemethod(_xapian.WritableDatabase_delete_document,None,WritableDatabase)
  3273. WritableDatabase.replace_document = new_instancemethod(_xapian.WritableDatabase_replace_document,None,WritableDatabase)
  3274. WritableDatabase.add_spelling = new_instancemethod(_xapian.WritableDatabase_add_spelling,None,WritableDatabase)
  3275. WritableDatabase.remove_spelling = new_instancemethod(_xapian.WritableDatabase_remove_spelling,None,WritableDatabase)
  3276. WritableDatabase.add_synonym = new_instancemethod(_xapian.WritableDatabase_add_synonym,None,WritableDatabase)
  3277. WritableDatabase.remove_synonym = new_instancemethod(_xapian.WritableDatabase_remove_synonym,None,WritableDatabase)
  3278. WritableDatabase.clear_synonyms = new_instancemethod(_xapian.WritableDatabase_clear_synonyms,None,WritableDatabase)
  3279. WritableDatabase.set_metadata = new_instancemethod(_xapian.WritableDatabase_set_metadata,None,WritableDatabase)
  3280. WritableDatabase.__str__ = new_instancemethod(_xapian.WritableDatabase___str__,None,WritableDatabase)
  3281. WritableDatabase.get_description = new_instancemethod(_xapian.WritableDatabase_get_description,None,WritableDatabase)
  3282. WritableDatabase_swigregister = _xapian.WritableDatabase_swigregister
  3283. WritableDatabase_swigregister(WritableDatabase)
  3284.  
  3285. DB_CREATE_OR_OPEN = _xapian.DB_CREATE_OR_OPEN
  3286. DB_CREATE = _xapian.DB_CREATE
  3287. DB_CREATE_OR_OVERWRITE = _xapian.DB_CREATE_OR_OVERWRITE
  3288. DB_OPEN = _xapian.DB_OPEN
  3289.  
  3290. def open_stub(*args):
  3291.   """
  3292.     Construct a Database object for a stub database file.
  3293.  
  3294.     XAPIAN_VISIBILITY_DEFAULT Database Xapian::Auto::open_stub(const
  3295.     std::string &file)
  3296.  
  3297.     The stub database file contains serialised parameters for one or more
  3298.     databases.
  3299.  
  3300.     Parameters:
  3301.     -----------
  3302.  
  3303.     file:  pathname of the stub database file. 
  3304.     """
  3305.   return _xapian.open_stub(*args)
  3306.  
  3307. def inmemory_open(*args):
  3308.   """
  3309.     Construct a WritableDatabase object for a new, empty InMemory
  3310.     database.
  3311.  
  3312.     XAPIAN_VISIBILITY_DEFAULT WritableDatabase Xapian::InMemory::open()
  3313.  
  3314.     Only a writable InMemory database can be created, since a read-only
  3315.     one would always remain empty. 
  3316.     """
  3317.   return _xapian.inmemory_open(*args)
  3318. class Query(object):
  3319.     """
  3320.     Class representing a query.
  3321.  
  3322.     Queries are represented as a tree of objects. 
  3323.     """
  3324.     thisown = _swig_property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc='The membership flag')
  3325.     __repr__ = _swig_repr
  3326.     OP_AND = _xapian.Query_OP_AND
  3327.     OP_OR = _xapian.Query_OP_OR
  3328.     OP_AND_NOT = _xapian.Query_OP_AND_NOT
  3329.     OP_XOR = _xapian.Query_OP_XOR
  3330.     OP_AND_MAYBE = _xapian.Query_OP_AND_MAYBE
  3331.     OP_FILTER = _xapian.Query_OP_FILTER
  3332.     OP_NEAR = _xapian.Query_OP_NEAR
  3333.     OP_PHRASE = _xapian.Query_OP_PHRASE
  3334.     OP_VALUE_RANGE = _xapian.Query_OP_VALUE_RANGE
  3335.     OP_SCALE_WEIGHT = _xapian.Query_OP_SCALE_WEIGHT
  3336.     OP_ELITE_SET = _xapian.Query_OP_ELITE_SET
  3337.     OP_VALUE_GE = _xapian.Query_OP_VALUE_GE
  3338.     OP_VALUE_LE = _xapian.Query_OP_VALUE_LE
  3339.     def __init__(self, *args): 
  3340.         """
  3341.         Construct a value comparison query on a document value.
  3342.  
  3343.         Xapian::Query::Query(Query::op op_, Xapian::valueno valno, const
  3344.         std::string &value)
  3345.  
  3346.         This query matches those documents which have a value stored in the
  3347.         slot given by valno which compares, as specified by the operator, to
  3348.         value.
  3349.  
  3350.         Parameters:
  3351.         -----------
  3352.  
  3353.         op_:  The operator to use for the query. Currently, must be
  3354.         OP_VALUE_GE or OP_VALUE_LE.
  3355.  
  3356.         valno:  The slot number to get the value from.
  3357.  
  3358.         value:  The value to compare. 
  3359.         """
  3360.         _xapian.Query_swiginit(self,_xapian.new_Query(*args))
  3361.     __swig_destroy__ = _xapian.delete_Query
  3362.     def get_length(*args):
  3363.         """
  3364.         Get the length of the query, used by some ranking formulae.
  3365.  
  3366.         Xapian::termcount Xapian::Query::get_length() const
  3367.  
  3368.         This value is calculated automatically - if you want to override it
  3369.         you can pass a different value to Enquire::set_query(). 
  3370.         """
  3371.         return _xapian.Query_get_length(*args)
  3372.  
  3373.     def get_terms_begin(*args):
  3374.         """
  3375.         Return a Xapian::TermIterator returning all the terms in the query, in
  3376.         order of termpos.
  3377.  
  3378.         TermIterator Xapian::Query::get_terms_begin() const
  3379.  
  3380.         If multiple terms have the same term position, their order is
  3381.         unspecified. Duplicates (same term and termpos) will be removed. 
  3382.         """
  3383.         return _xapian.Query_get_terms_begin(*args)
  3384.  
  3385.     def get_terms_end(*args):
  3386.         """
  3387.         Return a Xapian::TermIterator to the end of the list of terms in the
  3388.         query.
  3389.  
  3390.         TermIterator Xapian::Query::get_terms_end() const 
  3391.         """
  3392.         return _xapian.Query_get_terms_end(*args)
  3393.  
  3394.     def empty(*args):
  3395.         """
  3396.         Test if the query is empty (i.e.
  3397.  
  3398.         bool Xapian::Query::empty() const
  3399.  
  3400.         was constructed using the default ctor or with an empty iterator
  3401.         ctor). 
  3402.         """
  3403.         return _xapian.Query_empty(*args)
  3404.  
  3405.     def __str__(*args):
  3406.         """
  3407.         Return a string describing this object.
  3408.  
  3409.         std::string Xapian::Query::get_description() const 
  3410.         """
  3411.         return _xapian.Query___str__(*args)
  3412.  
  3413.     def get_description(*args):
  3414.         """
  3415.         Return a string describing this object.
  3416.  
  3417.         std::string Xapian::Query::get_description() const 
  3418.         """
  3419.         return _xapian.Query_get_description(*args)
  3420.  
  3421. Query.get_length = new_instancemethod(_xapian.Query_get_length,None,Query)
  3422. Query.get_terms_begin = new_instancemethod(_xapian.Query_get_terms_begin,None,Query)
  3423. Query.get_terms_end = new_instancemethod(_xapian.Query_get_terms_end,None,Query)
  3424. Query.empty = new_instancemethod(_xapian.Query_empty,None,Query)
  3425. Query.__str__ = new_instancemethod(_xapian.Query___str__,None,Query)
  3426. Query.get_description = new_instancemethod(_xapian.Query_get_description,None,Query)
  3427. Query_swigregister = _xapian.Query_swigregister
  3428. Query_swigregister(Query)
  3429. quartz_open = _xapian.quartz_open
  3430.  
  3431. def flint_open(*args):
  3432.   """
  3433.     Construct a Database object for update access to a Flint database.
  3434.  
  3435.     XAPIAN_VISIBILITY_DEFAULT WritableDatabase Xapian::Flint::open(const
  3436.     std::string &dir, int action, int block_size=8192)
  3437.  
  3438.     Parameters:
  3439.     -----------
  3440.  
  3441.     dir:  pathname of the directory containing the database.
  3442.  
  3443.     action:  determines handling of existing/non-existing database:
  3444.     Xapian::DB_CREATE fail if database already exist, otherwise create new
  3445.     database.
  3446.  
  3447.     Xapian::DB_CREATE_OR_OPEN open existing database, or create new
  3448.     database if none exists.
  3449.  
  3450.     Xapian::DB_CREATE_OR_OVERWRITE overwrite existing database, or create
  3451.     new database if none exists.
  3452.  
  3453.     Xapian::DB_OPEN open existing database, failing if none exists.
  3454.  
  3455.     block_size:  the Btree blocksize to use (in bytes), which must be a
  3456.     power of two between 2048 and 65536 (inclusive). The default (also
  3457.     used if an invalid value if passed) is 8192 bytes. This parameter is
  3458.     ignored when opening an existing database. 
  3459.     """
  3460.   return _xapian.flint_open(*args)
  3461.  
  3462. def remote_open(*args):
  3463.   """
  3464.     Construct a Database object for read-only access to a remote database
  3465.     accessed via a program.
  3466.  
  3467.     XAPIAN_VISIBILITY_DEFAULT Database Xapian::Remote::open(const
  3468.     std::string &program, const std::string &args, Xapian::timeout
  3469.     timeout=10000)
  3470.  
  3471.     Access to the remote database is done by running an external program
  3472.     and communicating with it on stdin/stdout.
  3473.  
  3474.     Parameters:
  3475.     -----------
  3476.  
  3477.     program:  the external program to run.
  3478.  
  3479.     args:  space-separated list of arguments to pass to program.
  3480.  
  3481.     timeout:  timeout in milliseconds. If this timeout is exceeded for any
  3482.     individual operation on the remote database then
  3483.     Xapian::NetworkTimeoutError is thrown. A timeout of 0 means don't
  3484.     timeout. (Default is 10000ms, which is 10 seconds). 
  3485.     """
  3486.   return _xapian.remote_open(*args)
  3487.  
  3488. def remote_open_writable(*args):
  3489.   """
  3490.     Construct a WritableDatabase object for update access to a remote
  3491.     database accessed via a program.
  3492.  
  3493.     XAPIAN_VISIBILITY_DEFAULT WritableDatabase
  3494.     Xapian::Remote::open_writable(const std::string &program, const
  3495.     std::string &args, Xapian::timeout timeout=0)
  3496.  
  3497.     Access to the remote database is done by running an external program
  3498.     and communicating with it on stdin/stdout.
  3499.  
  3500.     Parameters:
  3501.     -----------
  3502.  
  3503.     program:  the external program to run.
  3504.  
  3505.     args:  space-separated list of arguments to pass to program.
  3506.  
  3507.     timeout:  timeout in milliseconds. If this timeout is exceeded for any
  3508.     individual operation on the remote database then
  3509.     Xapian::NetworkTimeoutError is thrown. (Default is 0, which means
  3510.     don't timeout). 
  3511.     """
  3512.   return _xapian.remote_open_writable(*args)
  3513.  
  3514. class Stopper(object):
  3515.     """
  3516.     Base class for stop-word decision functor. 
  3517.     """
  3518.     thisown = _swig_property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc='The membership flag')
  3519.     __repr__ = _swig_repr
  3520.     __swig_destroy__ = _xapian.delete_Stopper
  3521.     def __str__(*args):
  3522.         """
  3523.         Return a string describing this object.
  3524.  
  3525.         virtual std::string Xapian::Stopper::get_description() const 
  3526.         """
  3527.         return _xapian.Stopper___str__(*args)
  3528.  
  3529.     def get_description(*args):
  3530.         """
  3531.         Return a string describing this object.
  3532.  
  3533.         virtual std::string Xapian::Stopper::get_description() const 
  3534.         """
  3535.         return _xapian.Stopper_get_description(*args)
  3536.  
  3537.     def __init__(self, *args): 
  3538.         if self.__class__ == Stopper:
  3539.             args = (None,) + args
  3540.         else:
  3541.             args = (self,) + args
  3542.         _xapian.Stopper_swiginit(self,_xapian.new_Stopper(*args))
  3543.     def __disown__(self):
  3544.         self.this.disown()
  3545.         _xapian.disown_Stopper(self)
  3546.         return weakref_proxy(self)
  3547. Stopper.__call__ = new_instancemethod(_xapian.Stopper___call__,None,Stopper)
  3548. Stopper.__str__ = new_instancemethod(_xapian.Stopper___str__,None,Stopper)
  3549. Stopper.get_description = new_instancemethod(_xapian.Stopper_get_description,None,Stopper)
  3550. Stopper_swigregister = _xapian.Stopper_swigregister
  3551. Stopper_swigregister(Stopper)
  3552.  
  3553. class SimpleStopper(Stopper):
  3554.     """
  3555.     Simple implementation of Stopper class - this will suit most users. 
  3556.     """
  3557.     thisown = _swig_property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc='The membership flag')
  3558.     __repr__ = _swig_repr
  3559.     def __init__(self, *args): 
  3560.         """
  3561.         Initialise from a pair of iterators.
  3562.  
  3563.         Xapian::SimpleStopper::SimpleStopper(Iterator begin, Iterator end) 
  3564.         """
  3565.         _xapian.SimpleStopper_swiginit(self,_xapian.new_SimpleStopper(*args))
  3566.     def add(*args):
  3567.         """
  3568.         Add a single stop word.
  3569.  
  3570.         void Xapian::SimpleStopper::add(const std::string &word) 
  3571.         """
  3572.         return _xapian.SimpleStopper_add(*args)
  3573.  
  3574.     __swig_destroy__ = _xapian.delete_SimpleStopper
  3575. SimpleStopper.add = new_instancemethod(_xapian.SimpleStopper_add,None,SimpleStopper)
  3576. SimpleStopper_swigregister = _xapian.SimpleStopper_swigregister
  3577. SimpleStopper_swigregister(SimpleStopper)
  3578.  
  3579. class ValueRangeProcessor(object):
  3580.     """
  3581.     Base class for value range processors. 
  3582.     """
  3583.     thisown = _swig_property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc='The membership flag')
  3584.     __repr__ = _swig_repr
  3585.     __swig_destroy__ = _xapian.delete_ValueRangeProcessor
  3586.     def __init__(self, *args): 
  3587.         if self.__class__ == ValueRangeProcessor:
  3588.             args = (None,) + args
  3589.         else:
  3590.             args = (self,) + args
  3591.         _xapian.ValueRangeProcessor_swiginit(self,_xapian.new_ValueRangeProcessor(*args))
  3592.     def __disown__(self):
  3593.         self.this.disown()
  3594.         _xapian.disown_ValueRangeProcessor(self)
  3595.         return weakref_proxy(self)
  3596. ValueRangeProcessor.__call__ = new_instancemethod(_xapian.ValueRangeProcessor___call__,None,ValueRangeProcessor)
  3597. ValueRangeProcessor_swigregister = _xapian.ValueRangeProcessor_swigregister
  3598. ValueRangeProcessor_swigregister(ValueRangeProcessor)
  3599.  
  3600. class StringValueRangeProcessor(ValueRangeProcessor):
  3601.     """
  3602.     Handle a string range.
  3603.  
  3604.     The end points can be any strings. 
  3605.     """
  3606.     thisown = _swig_property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc='The membership flag')
  3607.     __repr__ = _swig_repr
  3608.     def __init__(self, *args): 
  3609.         """
  3610.         Constructor.
  3611.  
  3612.         Xapian::StringValueRangeProcessor::StringValueRangeProcessor(Xapian::v
  3613.         alueno valno_)
  3614.  
  3615.         Parameters:
  3616.         -----------
  3617.  
  3618.         valno_:  The value number to return from operator(). 
  3619.         """
  3620.         _xapian.StringValueRangeProcessor_swiginit(self,_xapian.new_StringValueRangeProcessor(*args))
  3621.     __swig_destroy__ = _xapian.delete_StringValueRangeProcessor
  3622. StringValueRangeProcessor_swigregister = _xapian.StringValueRangeProcessor_swigregister
  3623. StringValueRangeProcessor_swigregister(StringValueRangeProcessor)
  3624.  
  3625. class DateValueRangeProcessor(ValueRangeProcessor):
  3626.     """
  3627.     Handle a date range.
  3628.  
  3629.     Begin and end must be dates in a recognised format. 
  3630.     """
  3631.     thisown = _swig_property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc='The membership flag')
  3632.     __repr__ = _swig_repr
  3633.     def __init__(self, *args): 
  3634.         """
  3635.         Constructor.
  3636.  
  3637.         Xapian::DateValueRangeProcessor::DateValueRangeProcessor(Xapian::value
  3638.         no valno_, bool prefer_mdy_=false, int epoch_year_=1970)
  3639.  
  3640.         Parameters:
  3641.         -----------
  3642.  
  3643.         valno_:  The value number to return from operator().
  3644.  
  3645.         prefer_mdy_:  Should ambiguous dates be interpreted as month/day/year
  3646.         rather than day/month/year? (default: false)
  3647.  
  3648.         epoch_year_:  Year to use as the epoch for dates with 2 digit years
  3649.         (default: 1970, so 1/1/69 is 2069 while 1/1/70 is 1970). 
  3650.         """
  3651.         _xapian.DateValueRangeProcessor_swiginit(self,_xapian.new_DateValueRangeProcessor(*args))
  3652.     __swig_destroy__ = _xapian.delete_DateValueRangeProcessor
  3653. DateValueRangeProcessor_swigregister = _xapian.DateValueRangeProcessor_swigregister
  3654. DateValueRangeProcessor_swigregister(DateValueRangeProcessor)
  3655.  
  3656. class NumberValueRangeProcessor(ValueRangeProcessor):
  3657.     thisown = _swig_property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc='The membership flag')
  3658.     __repr__ = _swig_repr
  3659.     def __init__(self, *args): 
  3660.         _xapian.NumberValueRangeProcessor_swiginit(self,_xapian.new_NumberValueRangeProcessor(*args))
  3661.     __swig_destroy__ = _xapian.delete_NumberValueRangeProcessor
  3662. NumberValueRangeProcessor_swigregister = _xapian.NumberValueRangeProcessor_swigregister
  3663. NumberValueRangeProcessor_swigregister(NumberValueRangeProcessor)
  3664.  
  3665. class QueryParser(object):
  3666.     """
  3667.     Build a Xapian::Query object from a user query string. 
  3668.     """
  3669.     thisown = _swig_property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc='The membership flag')
  3670.     __repr__ = _swig_repr
  3671.     FLAG_BOOLEAN = _xapian.QueryParser_FLAG_BOOLEAN
  3672.     FLAG_PHRASE = _xapian.QueryParser_FLAG_PHRASE
  3673.     FLAG_LOVEHATE = _xapian.QueryParser_FLAG_LOVEHATE
  3674.     FLAG_BOOLEAN_ANY_CASE = _xapian.QueryParser_FLAG_BOOLEAN_ANY_CASE
  3675.     FLAG_WILDCARD = _xapian.QueryParser_FLAG_WILDCARD
  3676.     FLAG_PURE_NOT = _xapian.QueryParser_FLAG_PURE_NOT
  3677.     FLAG_PARTIAL = _xapian.QueryParser_FLAG_PARTIAL
  3678.     FLAG_SPELLING_CORRECTION = _xapian.QueryParser_FLAG_SPELLING_CORRECTION
  3679.     FLAG_SYNONYM = _xapian.QueryParser_FLAG_SYNONYM
  3680.     FLAG_AUTO_SYNONYMS = _xapian.QueryParser_FLAG_AUTO_SYNONYMS
  3681.     FLAG_AUTO_MULTIWORD_SYNONYMS = _xapian.QueryParser_FLAG_AUTO_MULTIWORD_SYNONYMS
  3682.     FLAG_DEFAULT = _xapian.QueryParser_FLAG_DEFAULT
  3683.     STEM_NONE = _xapian.QueryParser_STEM_NONE
  3684.     STEM_SOME = _xapian.QueryParser_STEM_SOME
  3685.     STEM_ALL = _xapian.QueryParser_STEM_ALL
  3686.     def __init__(self, *args): 
  3687.         """
  3688.         Default constructor.
  3689.  
  3690.         Xapian::QueryParser::QueryParser() 
  3691.         """
  3692.         _xapian.QueryParser_swiginit(self,_xapian.new_QueryParser(*args))
  3693.     __swig_destroy__ = _xapian.delete_QueryParser
  3694.     def set_stemmer(*args):
  3695.         """
  3696.         Set the stemmer.
  3697.  
  3698.         void Xapian::QueryParser::set_stemmer(const Xapian::Stem &stemmer)
  3699.  
  3700.         This sets the stemming algorithm which will be used by the query
  3701.         parser. Note that the stemming algorithm will only be used according
  3702.         to the stemming strategy set by set_stemming_strategy(), which
  3703.         defaults to STEM_NONE. Therefore, to use a stemming algorithm, you
  3704.         will also need to call set_stemming_strategy() with a value other than
  3705.         STEM_NONE. 
  3706.         """
  3707.         return _xapian.QueryParser_set_stemmer(*args)
  3708.  
  3709.     def set_stemming_strategy(*args):
  3710.         """
  3711.         Set the stemming strategy.
  3712.  
  3713.         void Xapian::QueryParser::set_stemming_strategy(stem_strategy
  3714.         strategy)
  3715.  
  3716.         This controls how the query parser will apply the stemming algorithm.
  3717.         The default value is STEM_NONE. The possible values are:
  3718.  
  3719.         STEM_NONE: Don't perform any stemming.
  3720.  
  3721.         STEM_SOME: Search for stemmed forms of terms except for those which
  3722.         start with a capital letter, or are followed by certain characters
  3723.         (currently: (/@<>=*[{" ), or are used with operators which need
  3724.         positional information. Stemmed terms are prefixed with 'Z'.
  3725.  
  3726.         STEM_ALL: Search for stemmed forms of all words (note: no 'Z' prefix
  3727.         is added).
  3728.  
  3729.         Note that the stemming algorithm is only applied to words in
  3730.         probabilistic fields - boolean filter terms are never stemmed. 
  3731.         """
  3732.         return _xapian.QueryParser_set_stemming_strategy(*args)
  3733.  
  3734.     def set_stopper(*args):
  3735.         """
  3736.         Set the stopper.
  3737.  
  3738.         void Xapian::QueryParser::set_stopper(const Stopper *stop=NULL) 
  3739.         """
  3740.         return _xapian.QueryParser_set_stopper(*args)
  3741.  
  3742.     def set_default_op(*args):
  3743.         """
  3744.         Set the default boolean operator.
  3745.  
  3746.         void Xapian::QueryParser::set_default_op(Query::op default_op) 
  3747.         """
  3748.         return _xapian.QueryParser_set_default_op(*args)
  3749.  
  3750.     def get_default_op(*args):
  3751.         """
  3752.         Get the default boolean operator.
  3753.  
  3754.         Query::op Xapian::QueryParser::get_default_op() const 
  3755.         """
  3756.         return _xapian.QueryParser_get_default_op(*args)
  3757.  
  3758.     def set_database(*args):
  3759.         """
  3760.         Specify the database being searched.
  3761.  
  3762.         void Xapian::QueryParser::set_database(const Database &db) 
  3763.         """
  3764.         return _xapian.QueryParser_set_database(*args)
  3765.  
  3766.     def parse_query(*args):
  3767.         """
  3768.         Parse a query.
  3769.  
  3770.         Query Xapian::QueryParser::parse_query(const std::string
  3771.         &query_string, unsigned flags=FLAG_PHRASE|FLAG_BOOLEAN|FLAG_LOVEHATE,
  3772.         const std::string &default_prefix="")
  3773.  
  3774.         Parameters:
  3775.         -----------
  3776.  
  3777.         query_string:  A free-text query as entered by a user
  3778.  
  3779.         flags:  Zero or more Query::feature_flag specifying what features the
  3780.         QueryParser should support. Combine multiple values with bitwise-or
  3781.         (|) (default FLAG_DEFAULT).
  3782.  
  3783.         default_prefix:  The default term prefix to use (default none). For
  3784.         example, you can pass "A" when parsing an "Author" field. 
  3785.         """
  3786.         return _xapian.QueryParser_parse_query(*args)
  3787.  
  3788.     def add_prefix(*args):
  3789.         """
  3790.         Add a probabilistic term prefix.
  3791.  
  3792.         void Xapian::QueryParser::add_prefix(const std::string &field, const
  3793.         std::string &prefix)
  3794.  
  3795.         For example:
  3796.  
  3797.         This allows the user to search for author:Orwell which will be
  3798.         converted to a search for the term "Aorwell".
  3799.  
  3800.         Multiple fields can be mapped to the same prefix. For example, you can
  3801.         make title: and subject: aliases for each other.
  3802.  
  3803.         As of 1.0.4, you can call this method multiple times with the same
  3804.         value of field to allow a single field to be mapped to multiple
  3805.         prefixes. Multiple terms being generated for such a field, and
  3806.         combined with  Xapian::Query::OP_OR.
  3807.  
  3808.         If any prefixes are specified for the empty field name (i.e. you call
  3809.         this method with an empty string as the first parameter) these
  3810.         prefixes will be used as the default prefix. If you do this and also
  3811.         specify the default_prefix parameter to  parse_query(), then the
  3812.         default_prefix parameter will override.
  3813.  
  3814.         If you call  add_prefix() and  add_boolean_prefix() for the same value
  3815.         of field, a Xapian::InvalidOperationError exception will be thrown.
  3816.  
  3817.         In 1.0.3 and earlier, subsequent calls to this method with the same
  3818.         value of field had no effect.
  3819.  
  3820.         Parameters:
  3821.         -----------
  3822.  
  3823.         field:  The user visible field name
  3824.  
  3825.         prefix:  The term prefix to map this to 
  3826.         """
  3827.         return _xapian.QueryParser_add_prefix(*args)
  3828.  
  3829.     def add_boolean_prefix(*args):
  3830.         """
  3831.         Add a boolean term prefix allowing the user to restrict a search with
  3832.         a boolean filter specified in the free text query.
  3833.  
  3834.         void Xapian::QueryParser::add_boolean_prefix(const std::string &field,
  3835.         const std::string &prefix)
  3836.  
  3837.         For example:
  3838.  
  3839.         This allows the user to restrict a search with site:xapian.org which
  3840.         will be converted to Hxapian.org combined with any probabilistic query
  3841.         with  Xapian::Query::OP_FILTER.
  3842.  
  3843.         If multiple boolean filters are specified in a query for the same
  3844.         prefix, they will be combined with the  Xapian::Query::OP_OR operator.
  3845.         Then, if there are boolean filters for different prefixes, they will
  3846.         be combined with the  Xapian::Query::OP_AND operator.
  3847.  
  3848.         Multiple fields can be mapped to the same prefix (so for example you
  3849.         can make site: and domain: aliases for each other). Instances of
  3850.         fields with different aliases but the same prefix will still be
  3851.         combined with the OR operator.
  3852.  
  3853.         For example, if "site" and "domain" map to "H", but author maps
  3854.         to "A", a search for "site:foo domain:bar author:Fred" will map to
  3855.         "(Hfoo OR Hbar) AND Afred".
  3856.  
  3857.         As of 1.0.4, you can call this method multiple times with the same
  3858.         value of field to allow a single field to be mapped to multiple
  3859.         prefixes. Multiple terms being generated for such a field, and
  3860.         combined with  Xapian::Query::OP_OR.
  3861.  
  3862.         Calling this method with an empty string for field will cause a
  3863.         Xapian::InvalidArgumentError.
  3864.  
  3865.         If you call  add_prefix() and  add_boolean_prefix() for the same value
  3866.         of field, a Xapian::InvalidOperationError exception will be thrown.
  3867.  
  3868.         In 1.0.3 and earlier, subsequent calls to this method with the same
  3869.         value of field had no effect.
  3870.  
  3871.         Parameters:
  3872.         -----------
  3873.  
  3874.         field:  The user visible field name
  3875.  
  3876.         prefix:  The term prefix to map this to 
  3877.         """
  3878.         return _xapian.QueryParser_add_boolean_prefix(*args)
  3879.  
  3880.     def stoplist_begin(*args):
  3881.         """
  3882.         Iterate over terms omitted from the query as stopwords.
  3883.  
  3884.         TermIterator Xapian::QueryParser::stoplist_begin() const 
  3885.         """
  3886.         return _xapian.QueryParser_stoplist_begin(*args)
  3887.  
  3888.     def stoplist_end(*args):
  3889.         """TermIterator Xapian::QueryParser::stoplist_end() const """
  3890.         return _xapian.QueryParser_stoplist_end(*args)
  3891.  
  3892.     def unstem_begin(*args):
  3893.         """
  3894.         Iterate over unstemmed forms of the given (stemmed) term used in the
  3895.         query.
  3896.  
  3897.         TermIterator Xapian::QueryParser::unstem_begin(const std::string
  3898.         &term) const 
  3899.         """
  3900.         return _xapian.QueryParser_unstem_begin(*args)
  3901.  
  3902.     def unstem_end(*args):
  3903.         """
  3904.         TermIterator
  3905.         Xapian::QueryParser::unstem_end(const std::string &) const 
  3906.         """
  3907.         return _xapian.QueryParser_unstem_end(*args)
  3908.  
  3909.     def add_valuerangeprocessor(*args):
  3910.         """
  3911.         Register a ValueRangeProcessor.
  3912.  
  3913.         void Xapian::QueryParser::add_valuerangeprocessor(Xapian::ValueRangePr
  3914.         ocessor *vrproc) 
  3915.         """
  3916.         return _xapian.QueryParser_add_valuerangeprocessor(*args)
  3917.  
  3918.     def get_corrected_query_string(*args):
  3919.         """
  3920.         Get the spelling-corrected query string.
  3921.  
  3922.         std::string Xapian::QueryParser::get_corrected_query_string() const
  3923.  
  3924.         This will only be set if FLAG_SPELLING_CORRECTION is specified when
  3925.         QueryParser::parse_query() was last called.
  3926.  
  3927.         If there were no corrections, an empty string is returned. 
  3928.         """
  3929.         return _xapian.QueryParser_get_corrected_query_string(*args)
  3930.  
  3931.     def __str__(*args):
  3932.         """
  3933.         Return a string describing this object.
  3934.  
  3935.         std::string Xapian::QueryParser::get_description() const 
  3936.         """
  3937.         return _xapian.QueryParser___str__(*args)
  3938.  
  3939.     def get_description(*args):
  3940.         """
  3941.         Return a string describing this object.
  3942.  
  3943.         std::string Xapian::QueryParser::get_description() const 
  3944.         """
  3945.         return _xapian.QueryParser_get_description(*args)
  3946.  
  3947. QueryParser.set_stemmer = new_instancemethod(_xapian.QueryParser_set_stemmer,None,QueryParser)
  3948. QueryParser.set_stemming_strategy = new_instancemethod(_xapian.QueryParser_set_stemming_strategy,None,QueryParser)
  3949. QueryParser.set_stopper = new_instancemethod(_xapian.QueryParser_set_stopper,None,QueryParser)
  3950. QueryParser.set_default_op = new_instancemethod(_xapian.QueryParser_set_default_op,None,QueryParser)
  3951. QueryParser.get_default_op = new_instancemethod(_xapian.QueryParser_get_default_op,None,QueryParser)
  3952. QueryParser.set_database = new_instancemethod(_xapian.QueryParser_set_database,None,QueryParser)
  3953. QueryParser.parse_query = new_instancemethod(_xapian.QueryParser_parse_query,None,QueryParser)
  3954. QueryParser.add_prefix = new_instancemethod(_xapian.QueryParser_add_prefix,None,QueryParser)
  3955. QueryParser.add_boolean_prefix = new_instancemethod(_xapian.QueryParser_add_boolean_prefix,None,QueryParser)
  3956. QueryParser.stoplist_begin = new_instancemethod(_xapian.QueryParser_stoplist_begin,None,QueryParser)
  3957. QueryParser.stoplist_end = new_instancemethod(_xapian.QueryParser_stoplist_end,None,QueryParser)
  3958. QueryParser.unstem_begin = new_instancemethod(_xapian.QueryParser_unstem_begin,None,QueryParser)
  3959. QueryParser.unstem_end = new_instancemethod(_xapian.QueryParser_unstem_end,None,QueryParser)
  3960. QueryParser.add_valuerangeprocessor = new_instancemethod(_xapian.QueryParser_add_valuerangeprocessor,None,QueryParser)
  3961. QueryParser.get_corrected_query_string = new_instancemethod(_xapian.QueryParser_get_corrected_query_string,None,QueryParser)
  3962. QueryParser.__str__ = new_instancemethod(_xapian.QueryParser___str__,None,QueryParser)
  3963. QueryParser.get_description = new_instancemethod(_xapian.QueryParser_get_description,None,QueryParser)
  3964. QueryParser_swigregister = _xapian.QueryParser_swigregister
  3965. QueryParser_swigregister(QueryParser)
  3966.  
  3967. sortable_serialise = _xapian.sortable_serialise
  3968. sortable_unserialise = _xapian.sortable_unserialise
  3969. class Stem(object):
  3970.     """
  3971.     Class representing a stemming algorithm. 
  3972.     """
  3973.     thisown = _swig_property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc='The membership flag')
  3974.     __repr__ = _swig_repr
  3975.     def __init__(self, *args): 
  3976.         """
  3977.         Construct a Xapian::Stem object for a particular language.
  3978.  
  3979.         Xapian::Stem::Stem(const std::string &language)
  3980.  
  3981.         Parameters:
  3982.         -----------
  3983.  
  3984.         language:  Either the English name for the language or the two letter
  3985.         ISO639 code.
  3986.  
  3987.         The following language names are understood (aliases follow the name):
  3988.  
  3989.         none - don't stem terms
  3990.  
  3991.         danish (da)
  3992.  
  3993.         dutch (nl)
  3994.  
  3995.         english (en) - Martin Porter's 2002 revision of his stemmer
  3996.  
  3997.         english_lovins (lovins) - Lovin's stemmer
  3998.  
  3999.         english_porter (porter) - Porter's stemmer as described in his 1980
  4000.         paper
  4001.  
  4002.         finnish (fi)
  4003.  
  4004.         french (fr)
  4005.  
  4006.         german (de)
  4007.  
  4008.         italian (it)
  4009.  
  4010.         norwegian (no)
  4011.  
  4012.         portuguese (pt)
  4013.  
  4014.         russian (ru)
  4015.  
  4016.         spanish (es)
  4017.  
  4018.         swedish (sv)
  4019.  
  4020.         Parameters:
  4021.         -----------
  4022.  
  4023.         Xapian::InvalidArgumentError:  is thrown if language isn't recognised.
  4024.  
  4025.         """
  4026.         _xapian.Stem_swiginit(self,_xapian.new_Stem(*args))
  4027.     __swig_destroy__ = _xapian.delete_Stem
  4028.     def __str__(*args):
  4029.         """
  4030.         Return a string describing this object.
  4031.  
  4032.         std::string Xapian::Stem::get_description() const 
  4033.         """
  4034.         return _xapian.Stem___str__(*args)
  4035.  
  4036.     get_available_languages = staticmethod(_xapian.Stem_get_available_languages)
  4037.     def get_description(*args):
  4038.         """
  4039.         Return a string describing this object.
  4040.  
  4041.         std::string Xapian::Stem::get_description() const 
  4042.         """
  4043.         return _xapian.Stem_get_description(*args)
  4044.  
  4045. Stem.__call__ = new_instancemethod(_xapian.Stem___call__,None,Stem)
  4046. Stem.__str__ = new_instancemethod(_xapian.Stem___str__,None,Stem)
  4047. Stem.get_description = new_instancemethod(_xapian.Stem_get_description,None,Stem)
  4048. Stem_swigregister = _xapian.Stem_swigregister
  4049. Stem_swigregister(Stem)
  4050. Stem_get_available_languages = _xapian.Stem_get_available_languages
  4051.  
  4052. class TermGenerator(object):
  4053.     """
  4054.     Parses a piece of text and generate terms.
  4055.  
  4056.     This module takes a piece of text and parses it to produce words which
  4057.     are then used to generate suitable terms for indexing. The terms
  4058.     generated are suitable for use with Query objects produced by the
  4059.     QueryParser class. 
  4060.     """
  4061.     thisown = _swig_property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc='The membership flag')
  4062.     __repr__ = _swig_repr
  4063.     def __init__(self, *args): 
  4064.         """
  4065.         Default constructor.
  4066.  
  4067.         Xapian::TermGenerator::TermGenerator() 
  4068.         """
  4069.         _xapian.TermGenerator_swiginit(self,_xapian.new_TermGenerator(*args))
  4070.     __swig_destroy__ = _xapian.delete_TermGenerator
  4071.     def set_stemmer(*args):
  4072.         """
  4073.         Set the Xapian::Stem object to be used for generating stemmed terms.
  4074.  
  4075.         void Xapian::TermGenerator::set_stemmer(const Xapian::Stem &stemmer)
  4076.  
  4077.         """
  4078.         return _xapian.TermGenerator_set_stemmer(*args)
  4079.  
  4080.     def set_stopper(*args):
  4081.         """
  4082.         Set the Xapian::Stopper object to be used for identifying stopwords.
  4083.  
  4084.         void Xapian::TermGenerator::set_stopper(const Xapian::Stopper
  4085.         *stop=NULL) 
  4086.         """
  4087.         return _xapian.TermGenerator_set_stopper(*args)
  4088.  
  4089.     def set_document(*args):
  4090.         """
  4091.         Set the current document.
  4092.  
  4093.         void Xapian::TermGenerator::set_document(const Xapian::Document &doc)
  4094.  
  4095.         """
  4096.         return _xapian.TermGenerator_set_document(*args)
  4097.  
  4098.     def get_document(*args):
  4099.         """
  4100.         Get the current document.
  4101.  
  4102.         const Xapian::Document& Xapian::TermGenerator::get_document() const 
  4103.         """
  4104.         return _xapian.TermGenerator_get_document(*args)
  4105.  
  4106.     def set_database(*args):
  4107.         """
  4108.         Set the database to index spelling data to.
  4109.  
  4110.         void Xapian::TermGenerator::set_database(const
  4111.         Xapian::WritableDatabase &db) 
  4112.         """
  4113.         return _xapian.TermGenerator_set_database(*args)
  4114.  
  4115.     FLAG_SPELLING = _xapian.TermGenerator_FLAG_SPELLING
  4116.     def set_flags(*args):
  4117.         """
  4118.         Set flags.
  4119.  
  4120.         flags Xapian::TermGenerator::set_flags(flags toggle, flags
  4121.         mask=flags(0))
  4122.  
  4123.         The new value of flags is: (flags & mask) ^ toggle
  4124.  
  4125.         To just set the flags, pass the new flags in toggle and the default
  4126.         value for mask.
  4127.  
  4128.         Parameters:
  4129.         -----------
  4130.  
  4131.         toggle:  Flags to XOR.
  4132.  
  4133.         mask:  Flags to AND with first.
  4134.  
  4135.         The old flags setting. 
  4136.         """
  4137.         return _xapian.TermGenerator_set_flags(*args)
  4138.  
  4139.     def index_text(*args):
  4140.         """
  4141.         Index some text in a std::string.
  4142.  
  4143.         void Xapian::TermGenerator::index_text(const std::string &text,
  4144.         Xapian::termcount weight=1, const std::string &prefix="")
  4145.  
  4146.         Parameters:
  4147.         -----------
  4148.  
  4149.         weight:  The wdf increment (default 1).
  4150.  
  4151.         prefix:  The term prefix to use (default is no prefix). 
  4152.         """
  4153.         return _xapian.TermGenerator_index_text(*args)
  4154.  
  4155.     def index_text_without_positions(*args):
  4156.         """
  4157.         Index some text in a std::string without positional information.
  4158.  
  4159.         void Xapian::TermGenerator::index_text_without_positions(const
  4160.         std::string &text, Xapian::termcount weight=1, const std::string
  4161.         &prefix="")
  4162.  
  4163.         Just like index_text, but no positional information is generated. This
  4164.         means that the database will be significantly smaller, but that phrase
  4165.         searching and NEAR won't be supported. 
  4166.         """
  4167.         return _xapian.TermGenerator_index_text_without_positions(*args)
  4168.  
  4169.     def increase_termpos(*args):
  4170.         """
  4171.         Increase the termpos used by index_text by delta.
  4172.  
  4173.         void Xapian::TermGenerator::increase_termpos(Xapian::termcount
  4174.         delta=100)
  4175.  
  4176.         This can be used to prevent phrase searches from spanning two
  4177.         unconnected blocks of text (e.g. the title and body text). 
  4178.         """
  4179.         return _xapian.TermGenerator_increase_termpos(*args)
  4180.  
  4181.     def get_termpos(*args):
  4182.         """
  4183.         Get the current term position.
  4184.  
  4185.         Xapian::termcount Xapian::TermGenerator::get_termpos() const 
  4186.         """
  4187.         return _xapian.TermGenerator_get_termpos(*args)
  4188.  
  4189.     def set_termpos(*args):
  4190.         """
  4191.         Set the current term position.
  4192.  
  4193.         void Xapian::TermGenerator::set_termpos(Xapian::termcount termpos) 
  4194.         """
  4195.         return _xapian.TermGenerator_set_termpos(*args)
  4196.  
  4197.     def __str__(*args):
  4198.         """
  4199.         Return a string describing this object.
  4200.  
  4201.         std::string Xapian::TermGenerator::get_description() const 
  4202.         """
  4203.         return _xapian.TermGenerator___str__(*args)
  4204.  
  4205. TermGenerator.set_stemmer = new_instancemethod(_xapian.TermGenerator_set_stemmer,None,TermGenerator)
  4206. TermGenerator.set_stopper = new_instancemethod(_xapian.TermGenerator_set_stopper,None,TermGenerator)
  4207. TermGenerator.set_document = new_instancemethod(_xapian.TermGenerator_set_document,None,TermGenerator)
  4208. TermGenerator.get_document = new_instancemethod(_xapian.TermGenerator_get_document,None,TermGenerator)
  4209. TermGenerator.set_database = new_instancemethod(_xapian.TermGenerator_set_database,None,TermGenerator)
  4210. TermGenerator.set_flags = new_instancemethod(_xapian.TermGenerator_set_flags,None,TermGenerator)
  4211. TermGenerator.index_text = new_instancemethod(_xapian.TermGenerator_index_text,None,TermGenerator)
  4212. TermGenerator.index_text_without_positions = new_instancemethod(_xapian.TermGenerator_index_text_without_positions,None,TermGenerator)
  4213. TermGenerator.increase_termpos = new_instancemethod(_xapian.TermGenerator_increase_termpos,None,TermGenerator)
  4214. TermGenerator.get_termpos = new_instancemethod(_xapian.TermGenerator_get_termpos,None,TermGenerator)
  4215. TermGenerator.set_termpos = new_instancemethod(_xapian.TermGenerator_set_termpos,None,TermGenerator)
  4216. TermGenerator.__str__ = new_instancemethod(_xapian.TermGenerator___str__,None,TermGenerator)
  4217. TermGenerator_swigregister = _xapian.TermGenerator_swigregister
  4218. TermGenerator_swigregister(TermGenerator)
  4219.  
  4220. class Sorter(object):
  4221.     """
  4222.     Virtual base class for sorter functor. 
  4223.     """
  4224.     thisown = _swig_property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc='The membership flag')
  4225.     __repr__ = _swig_repr
  4226.     __swig_destroy__ = _xapian.delete_Sorter
  4227.     def __init__(self, *args): 
  4228.         if self.__class__ == Sorter:
  4229.             args = (None,) + args
  4230.         else:
  4231.             args = (self,) + args
  4232.         _xapian.Sorter_swiginit(self,_xapian.new_Sorter(*args))
  4233.     def __disown__(self):
  4234.         self.this.disown()
  4235.         _xapian.disown_Sorter(self)
  4236.         return weakref_proxy(self)
  4237. Sorter.__call__ = new_instancemethod(_xapian.Sorter___call__,None,Sorter)
  4238. Sorter_swigregister = _xapian.Sorter_swigregister
  4239. Sorter_swigregister(Sorter)
  4240.  
  4241. class MultiValueSorter(Sorter):
  4242.     """
  4243.     Sorter subclass which sorts by a several values.
  4244.  
  4245.     Results are ordered by the first value. In the event of a tie, the
  4246.     second is used. If this is the same for both, the third is used, and
  4247.     so on. 
  4248.     """
  4249.     thisown = _swig_property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc='The membership flag')
  4250.     __repr__ = _swig_repr
  4251.     def __init__(self, *args): 
  4252.         """
  4253.         Xapian::MultiValueSorter::MultiValueSorter(Iterator begin, Iterator
  4254.         end) 
  4255.         """
  4256.         _xapian.MultiValueSorter_swiginit(self,_xapian.new_MultiValueSorter(*args))
  4257.     def add(*args):
  4258.         """
  4259.         void
  4260.         Xapian::MultiValueSorter::add(Xapian::valueno valno, bool
  4261.         forward=true) 
  4262.         """
  4263.         return _xapian.MultiValueSorter_add(*args)
  4264.  
  4265.     __swig_destroy__ = _xapian.delete_MultiValueSorter
  4266. MultiValueSorter.add = new_instancemethod(_xapian.MultiValueSorter_add,None,MultiValueSorter)
  4267. MultiValueSorter_swigregister = _xapian.MultiValueSorter_swigregister
  4268. MultiValueSorter_swigregister(MultiValueSorter)
  4269.  
  4270. # Set the documentation format - this is used by tools like "epydoc" to decide
  4271. # how to format the documentation strings.
  4272. __docformat__ = "restructuredtext en"
  4273.  
  4274. class _SequenceMixIn(object):
  4275.     """Simple mixin class which provides a sequence API to a class.
  4276.  
  4277.     This is used to support the legacy API to iterators used for releases of
  4278.     Xapian earlier than 1.0.  It will be removed once this legacy API is
  4279.     removed in release 1.1.
  4280.  
  4281.     """
  4282.  
  4283.     __slots__ = ('_sequence_items', )
  4284.     def __init__(self, *args):
  4285.         """Initialise the sequence.
  4286.  
  4287.         *args holds the list of properties or property names to be returned, in
  4288.         the order they are returned by the sequence API.
  4289.         
  4290.         If an item in the list is a string, it is considered to be a property
  4291.         name; otherwise, it is considered to be a property value, and is
  4292.         returned without doing an attribute lookup.  (Yes, this is a nasty
  4293.         hack.  No, I don't care, because this is only a temporary piece of
  4294.         internal code.)
  4295.  
  4296.         """
  4297.         self._sequence_items = args
  4298.  
  4299.     def __len__(self):
  4300.         """Get the length of the sequence.
  4301.  
  4302.         Doesn't evaluate any of the lazily evaluated properties.
  4303.  
  4304.         """
  4305.         return len(self._sequence_items)
  4306.  
  4307.     def _get_single_item(self, index):
  4308.         """Get a single item.
  4309.  
  4310.         Used by __getitem__ to get individual items.
  4311.  
  4312.         """
  4313.         if not isinstance(index, basestring):
  4314.              return index
  4315.         return getattr(self, index)
  4316.  
  4317.     def __getitem__(self, key):
  4318.         """Get an item, or a slice of items, from the sequence.
  4319.  
  4320.         If any of the items are lazily evaluated properties, they will be
  4321.         evaluated here.
  4322.  
  4323.         """
  4324.         if isinstance(key, slice):
  4325.             return [self._get_single_item(i) for i in self._sequence_items[key]]
  4326.         return self._get_single_item(self._sequence_items[key])
  4327.  
  4328.     def __iter__(self):
  4329.         """Make an iterator for over the sequence.
  4330.  
  4331.         This simply copies the items into a list, and returns an iterator over
  4332.         it.  Any lazily evaluated properties will be evaluated here.
  4333.  
  4334.         """
  4335.         return iter(self[:])
  4336.  
  4337.  
  4338. ##################################
  4339. # Support for iteration of MSets #
  4340. ##################################
  4341.  
  4342. class MSetItem(_SequenceMixIn):
  4343.     """An item returned from iteration of the MSet.
  4344.  
  4345.     The item supports access to the following attributes and properties:
  4346.  
  4347.      - `docid`: The Xapian document ID corresponding to this MSet item.
  4348.      - `weight`: The weight corresponding to this MSet item.
  4349.      - `rank`: The rank of this MSet item.  The rank is the position in the
  4350.        total set of matching documents of this item.  The highest document is
  4351.        given a rank of 0.  If the MSet did not start at the highest matching
  4352.        document, because a non-zero 'start' parameter was supplied to
  4353.        get_mset(), the first document in the MSet will have a rank greater than
  4354.        0 (in fact, it will be equal to the value of 'start' supplied to
  4355.        get_mset()).
  4356.      - `percent`: The percentage score assigned to this MSet item.
  4357.      - `document`: The document for this MSet item.  This can be used to access
  4358.        the document data, or any other information stored in the document (such
  4359.        as term lists).  It is lazily evaluated.
  4360.      - `collapse_key`: The value of the key which was used for collapsing.
  4361.      - `collapse_count`: An estimate of the number of documents that have been
  4362.        collapsed into this one.
  4363.  
  4364.     The collapse count estimate will always be less than or equal to the actual
  4365.     number of other documents satisfying the match criteria with the same
  4366.     collapse key as this document.  If may be 0 even though there are other
  4367.     documents with the same collapse key which satisfying the match criteria.
  4368.     However if this method returns non-zero, there definitely are other such
  4369.     documents.  So this method may be used to inform the user that there are
  4370.     "at least N other matches in this group", or to control whether to offer a
  4371.     "show other documents in this group" feature (but note that it may not
  4372.     offer it in every case where it would show other documents).
  4373.  
  4374.     """
  4375.  
  4376.     __slots__ = ('_mset', '_firstitem', 'docid', 'weight', 'rank',
  4377.                  'percent', 'collapse_key', 'collapse_count', '_document', )
  4378.  
  4379.     def __init__(self, iter, mset):
  4380.         self._mset = mset
  4381.         self._firstitem = self._mset.get_firstitem()
  4382.         self.docid = iter.get_docid()
  4383.         self.weight = iter.get_weight()
  4384.         self.rank = iter.get_rank()
  4385.         self.percent = iter.get_percent()
  4386.         self.collapse_key = iter.get_collapse_key()
  4387.         self.collapse_count = iter.get_collapse_count()
  4388.         self._document = None
  4389.         _SequenceMixIn.__init__(self, 'docid', 'weight', 'rank', 'percent', 'document')
  4390.  
  4391.     def _get_document(self):
  4392.         if self._document is None:
  4393.             self._document = self._mset._get_hit_internal(self.rank - self._firstitem).get_document()
  4394.         return self._document
  4395.  
  4396.     # Deprecated methods: to be removed in 1.1.0
  4397.     def get_docid(self):
  4398.         "Deprecated method: use the `docid` property instead."
  4399.         return self.docid
  4400.     def get_weight(self):
  4401.         "Deprecated method: use the `weight` property instead."
  4402.         return self.weight
  4403.     def get_rank(self):
  4404.         "Deprecated method: use the `rank` property instead."
  4405.         return self.rank
  4406.     def get_percent(self):
  4407.         "Deprecated method: use the `percent` property instead."
  4408.         return self.percent
  4409.     def get_collapse_key(self):
  4410.         "Deprecated method: use the `collapse_key` property instead."
  4411.         return self.collapse_key
  4412.     def get_collapse_count(self):
  4413.         "Deprecated method: use the `collapse_count` property instead."
  4414.         return self.collapse_count
  4415.     def get_document(self):
  4416.         "Deprecated method: use the `document` property instead."
  4417.         return self.document
  4418.  
  4419.     document = property(_get_document, doc="The document object corresponding to this MSet item.")
  4420.  
  4421. class MSetIter(object):
  4422.     """An iterator over the items in an MSet.
  4423.  
  4424.     The iterator will return MSetItem objects, which will be evaluated lazily
  4425.     where appropriate.
  4426.  
  4427.     """
  4428.     __slots__ = ('_iter', '_end', '_mset')
  4429.     def __init__(self, mset):
  4430.         self._iter = mset.begin()
  4431.         self._end = mset.end()
  4432.         self._mset = mset
  4433.  
  4434.     def __iter__(self):
  4435.         return self
  4436.  
  4437.     def next(self):
  4438.         if self._iter == self._end:
  4439.             raise StopIteration
  4440.         else:
  4441.             r = MSetItem(self._iter, self._mset)
  4442.             self._iter.next()
  4443.             return r
  4444.  
  4445.  
  4446. # Modify the MSet to allow access to the python iterators, and have other
  4447. # convenience methods.
  4448.  
  4449. def _mset_gen_iter(self):
  4450.     """Return an iterator over the MSet.
  4451.  
  4452.     The iterator will return MSetItem objects, which will be evaluated lazily
  4453.     where appropriate.
  4454.  
  4455.     """
  4456.     return MSetIter(self)
  4457. MSet.__iter__ = _mset_gen_iter
  4458.  
  4459. MSet.__len__ = MSet.size
  4460.  
  4461. def _mset_getitem(self, index):
  4462.     """Get an item from the MSet.
  4463.  
  4464.     The supplied index is relative to the start of the MSet, not the absolute
  4465.     rank of the item.
  4466.  
  4467.     Returns an MSetItem.
  4468.  
  4469.     """
  4470.     if index < 0:
  4471.         index += len(self)
  4472.     if index < 0 or index >= len(self):
  4473.         raise IndexError("Mset index out of range")
  4474.     return MSetItem(self._get_hit_internal(index), self)
  4475. MSet.__getitem__ = _mset_getitem
  4476. MSet.get_hit = _mset_getitem
  4477.  
  4478. def _mset_contains(self, index):
  4479.     """Check if the Mset contains an item at the given index
  4480.  
  4481.     The supplied index is relative to the start of the MSet, not the absolute
  4482.     rank of the item.
  4483.  
  4484.     """
  4485.     return key >= 0 and key < len(self)
  4486. MSet.__contains__ = _mset_contains
  4487.  
  4488.  
  4489. ##################################
  4490. # Support for iteration of ESets #
  4491. ##################################
  4492.  
  4493. class ESetItem(_SequenceMixIn):
  4494.     """An item returned from iteration of the ESet.
  4495.  
  4496.     The item supports access to the following attributes:
  4497.  
  4498.      - `term`: The term corresponding to this ESet item.
  4499.      - `weight`: The weight corresponding to this ESet item.
  4500.  
  4501.     """
  4502.     __slots__ = ('term', 'weight')
  4503.  
  4504.     def __init__(self, iter):
  4505.         self.term = iter.get_term()
  4506.         self.weight = iter.get_weight()
  4507.         _SequenceMixIn.__init__(self, 'term', 'weight')
  4508.  
  4509. class ESetIter(object):
  4510.     """An iterator over the items in an ESet.
  4511.  
  4512.     The iterator will return ESetItem objects.
  4513.  
  4514.     """
  4515.     __slots__ = ('_iter', '_end')
  4516.     def __init__(self, eset):
  4517.         self._iter = eset.begin()
  4518.         self._end = eset.end()
  4519.  
  4520.     def __iter__(self):
  4521.         return self
  4522.  
  4523.     def next(self):
  4524.         if self._iter == self._end:
  4525.             raise StopIteration
  4526.         else:
  4527.             r = ESetItem(self._iter)
  4528.             self._iter.next()
  4529.             return r
  4530.  
  4531. # Modify the ESet to allow access to the python iterators, and have other
  4532. # convenience methods.
  4533.  
  4534. def _eset_gen_iter(self):
  4535.     """Return an iterator over the ESet.
  4536.     
  4537.     The iterator will return ESetItem objects.
  4538.  
  4539.     """
  4540.     return ESetIter(self)
  4541. ESet.__iter__ = _eset_gen_iter
  4542.  
  4543. ESet.__len__ = ESet.size
  4544.  
  4545.  
  4546. #######################################
  4547. # Support for iteration of term lists #
  4548. #######################################
  4549.  
  4550. class TermListItem(_SequenceMixIn):
  4551.     """An item returned from iteration of a term list.
  4552.  
  4553.     The item supports access to the following attributes and properties:
  4554.  
  4555.      - `term`: The term corresponding to this TermListItem.
  4556.      - `wdf`: The within document frequency of this term.
  4557.      - `termfreq`: The number of documents in the collection which are indexed
  4558.        by the term
  4559.      - `positer`: An iterator over the positions which the term appears at in
  4560.        the document.  This is only available until the iterator which returned
  4561.        this item next moves.
  4562.  
  4563.     """
  4564.     __slots__ = ('_iter', 'term', '_wdf', '_termfreq')
  4565.  
  4566.     def __init__(self, iter, term):
  4567.         self._iter = iter
  4568.         self.term = term
  4569.         self._wdf = None
  4570.         self._termfreq = None
  4571.  
  4572.         if iter._has_wdf == TermIter.EAGER:
  4573.             self._wdf = iter._iter.get_wdf()
  4574.         if iter._has_termfreq == TermIter.EAGER:
  4575.             self._termfreq = iter._iter.get_termfreq()
  4576.  
  4577.         # Support for sequence API
  4578.         sequence = ['term', 'wdf', 'termfreq', 'positer']
  4579.         if iter._has_wdf == TermIter.INVALID:
  4580.             sequence[1] = 0
  4581.         if iter._has_termfreq == TermIter.INVALID:
  4582.             sequence[2] = 0
  4583.         if iter._has_positions == TermIter.INVALID:
  4584.             sequence[3] = PositionIter()
  4585.         _SequenceMixIn.__init__(self, *sequence)
  4586.  
  4587.     def _get_wdf(self):
  4588.         """Get the within-document-frequency of the current term.
  4589.  
  4590.         This will raise a InvalidOperationError exception if the iterator this
  4591.         item came from doesn't support within-document-frequencies.
  4592.  
  4593.         """
  4594.         if self._wdf is None:
  4595.             if self._iter._has_wdf == TermIter.INVALID:
  4596.                 raise InvalidOperationError("Iterator does not support wdfs")
  4597.             if self.term is not self._iter._lastterm:
  4598.                 raise InvalidOperationError("Iterator has moved, and does not support random access")
  4599.             self._wdf = self._iter._iter.get_wdf()
  4600.         return self._wdf
  4601.     wdf = property(_get_wdf, doc=
  4602.     """The within-document-frequency of the current term (if meaningful).
  4603.  
  4604.     This will raise a InvalidOperationError exception if the iterator
  4605.     this item came from doesn't support within-document-frequencies.
  4606.  
  4607.     """)
  4608.  
  4609.     def _get_termfreq(self):
  4610.         """Get the term frequency.
  4611.  
  4612.         This is the number of documents in the collection which are indexed by
  4613.         the term.
  4614.  
  4615.         This will raise a InvalidOperationError exception if the iterator this
  4616.         item came from doesn't support term frequencies.
  4617.  
  4618.         """
  4619.         if self._termfreq is None:
  4620.             if self._iter._has_termfreq == TermIter.INVALID:
  4621.                 raise InvalidOperationError("Iterator does not support term frequencies")
  4622.             if self.term is not self._iter._lastterm:
  4623.                 raise InvalidOperationError("Iterator has moved, and does not support random access")
  4624.             self._termfreq = self._iter._iter.get_termfreq()
  4625.         return self._termfreq
  4626.     termfreq = property(_get_termfreq, doc=
  4627.     """The term frequency of the current term (if meaningful).
  4628.  
  4629.     This is the number of documents in the collection which are indexed by the
  4630.     term.
  4631.  
  4632.     This will raise a InvalidOperationError exception if the iterator
  4633.     this item came from doesn't support term frequencies.
  4634.  
  4635.     """)
  4636.  
  4637.     def _get_positer(self):
  4638.         """Get a position list iterator.
  4639.  
  4640.         The iterator will return integers representing the positions that the
  4641.         term occurs at.
  4642.  
  4643.         This will raise a InvalidOperationError exception if the iterator this
  4644.         item came from doesn't support position lists, or if the iterator has
  4645.         moved on since the item was returned from it.
  4646.  
  4647.         """
  4648.         if self._iter._has_positions == TermIter.INVALID:
  4649.             raise InvalidOperationError("Iterator does not support position lists")
  4650.         # Access to position lists is always lazy, so we don't need to check
  4651.         # _has_positions.
  4652.         if self.term is not self._iter._lastterm:
  4653.             raise InvalidOperationError("Iterator has moved, and does not support random access")
  4654.         return PositionIter(self._iter._iter.positionlist_begin(),
  4655.                             self._iter._iter.positionlist_end())
  4656.     positer = property(_get_positer, doc=
  4657.     """A position iterator for the current term (if meaningful).
  4658.  
  4659.     The iterator will return integers representing the positions that the term
  4660.     occurs at.
  4661.  
  4662.     This will raise a InvalidOperationError exception if the iterator this item
  4663.     came from doesn't support position lists, or if the iterator has moved on
  4664.     since the item was returned from it.
  4665.  
  4666.     """)
  4667.  
  4668.  
  4669. class TermIter(object):
  4670.     """An iterator over a term list.
  4671.  
  4672.     The iterator will return TermListItem objects, which will be evaluated
  4673.     lazily where appropriate.
  4674.  
  4675.     """
  4676.     __slots__ = ('_iter', '_end', '_has_termfreq', '_has_wdf',
  4677.                  '_has_positions', '_return_strings', '_lastterm', '_moved')
  4678.  
  4679.     INVALID = 0
  4680.     LAZY = 1
  4681.     EAGER = 2
  4682.  
  4683.     def __init__(self, start, end, has_termfreq=INVALID,
  4684.                  has_wdf=INVALID, has_positions=INVALID,
  4685.                  return_strings=False):
  4686.         self._iter = start
  4687.         self._end = end
  4688.         self._has_termfreq = has_termfreq
  4689.         self._has_wdf = has_wdf
  4690.         self._has_positions = has_positions
  4691.         assert(has_positions != TermIter.EAGER) # Can't do eager access to position lists
  4692.         self._return_strings = return_strings
  4693.         self._lastterm = None # Used to test if the iterator has moved
  4694.  
  4695.         # _moved is True if we've moved onto the next item.  This is needed so
  4696.         # that the iterator doesn't have to move on until just before next() is
  4697.         # called: since the iterator starts by pointing at a valid item, we
  4698.         # can't just call self._iter.next() unconditionally at the start of our
  4699.         # next() method.
  4700.         self._moved = True
  4701.  
  4702.     def __iter__(self):
  4703.         return self
  4704.  
  4705.     def next(self):
  4706.         if not self._moved:
  4707.             self._iter.next()
  4708.             self._moved = True
  4709.  
  4710.         if self._iter == self._end:
  4711.             self._lastterm = None
  4712.             raise StopIteration
  4713.         else:
  4714.             self._lastterm = self._iter.get_term()
  4715.             self._moved = False
  4716.             if self._return_strings:
  4717.                 return self._lastterm
  4718.             return TermListItem(self, self._lastterm)
  4719.  
  4720.     def skip_to(self, term):
  4721.         """Skip the iterator forward.
  4722.  
  4723.         The iterator is advanced to the first term at or after the current
  4724.         position which is greater than or equal to the supplied term.
  4725.  
  4726.         If there are no such items, this will raise StopIteration.
  4727.  
  4728.         This returns the item which the iterator is moved to.  The subsequent
  4729.         item will be returned the next time that next() is called (unless
  4730.         skip_to() is called again first).
  4731.  
  4732.         """
  4733.         if self._iter != self._end:
  4734.             self._iter.skip_to(term)
  4735.  
  4736.         if self._iter == self._end:
  4737.             self._lastterm = None
  4738.             self._moved = True
  4739.             raise StopIteration
  4740.  
  4741.         # Update self._lastterm if the iterator has moved.
  4742.         # TermListItems compare a saved value of lastterm with self._lastterm
  4743.         # with the object identity comparator, so it is important to ensure
  4744.         # that it does not get modified if the new term compares equal.
  4745.         newterm = self._iter.get_term()
  4746.         if newterm != self._lastterm:
  4747.             self._lastterm = newterm
  4748.  
  4749.         self._moved = False
  4750.         if self._return_strings:
  4751.             return self._lastterm
  4752.         return TermListItem(self, self._lastterm)
  4753.  
  4754. # Modify Enquire to add a "matching_terms()" method.
  4755. def _enquire_gen_iter(self, which):
  4756.     """Get an iterator over the terms which match a given match set item.
  4757.  
  4758.     The match set item to consider is specified by the `which` parameter, which
  4759.     may be a document ID, or an MSetItem object.
  4760.  
  4761.     The iterator will return string objects.
  4762.  
  4763.     """
  4764.     if isinstance(which, MSetItem):
  4765.         which = which.docid
  4766.     return TermIter(self.get_matching_terms_begin(which),
  4767.                     self.get_matching_terms_end(which),
  4768.                     return_strings=True)
  4769. Enquire.matching_terms = _enquire_gen_iter
  4770.  
  4771. # get_matching_terms() is deprecated, but does just the same as
  4772. # matching_terms()
  4773. Enquire.get_matching_terms = _enquire_gen_iter
  4774.  
  4775. # Modify Query to add an "__iter__()" method.
  4776. def _query_gen_iter(self):
  4777.     """Get an iterator over the terms in a query.
  4778.  
  4779.     The iterator will return string objects.
  4780.  
  4781.     """
  4782.     return TermIter(self.get_terms_begin(),
  4783.                     self.get_terms_end(),
  4784.                     return_strings=True)
  4785. Query.__iter__ = _query_gen_iter
  4786.  
  4787. # Modify Database to add an "__iter__()" method and an "allterms()" method.
  4788. def _database_gen_allterms_iter(self, prefix=None):
  4789.     """Get an iterator over all the terms in the database.
  4790.  
  4791.     The iterator will return TermListItem objects, but these will not support
  4792.     access to wdf, or position information.
  4793.  
  4794.     Access to term frequency information is only available until the iterator
  4795.     has moved on.
  4796.  
  4797.     If prefix is supplied, only terms which start with that prefix will be
  4798.     returned.
  4799.  
  4800.     """
  4801.     if prefix is None:
  4802.         return TermIter(self.allterms_begin(), self.allterms_end(),
  4803.                         has_termfreq=TermIter.LAZY)
  4804.     else:
  4805.         return TermIter(self.allterms_begin(prefix), self.allterms_end(prefix),
  4806.                         has_termfreq=TermIter.LAZY)
  4807. Database.__iter__ = _database_gen_allterms_iter
  4808. Database.allterms = _database_gen_allterms_iter
  4809.  
  4810. # Modify Database to add a "termlist()" method.
  4811. def _database_gen_termlist_iter(self, docid):
  4812.     """Get an iterator over all the terms which index a given document ID.
  4813.  
  4814.     The iterator will return TermListItem objects.
  4815.  
  4816.     Access to term frequency and position information is only available until
  4817.     the iterator has moved on.
  4818.  
  4819.     """
  4820.     # Note: has_termfreq is set to LAZY because most databases don't store term
  4821.     # frequencies in the termlist (because this would require updating many termlist
  4822.     # entries for every document update), so access to the term frequency requires a
  4823.     # separate lookup.
  4824.     return TermIter(self.termlist_begin(docid), self.termlist_end(docid),
  4825.                     has_termfreq=TermIter.LAZY,
  4826.                     has_wdf=TermIter.EAGER,
  4827.                     has_positions=TermIter.LAZY)
  4828. Database.termlist = _database_gen_termlist_iter
  4829.  
  4830. # Modify Database to add a "spellings()" method.
  4831. def _database_gen_spellings_iter(self):
  4832.     """Get an iterator which returns all the spelling correction targets
  4833.  
  4834.     The iterator will return TermListItem objects.  Only the term frequency is
  4835.     available; wdf and positions are not meaningful.
  4836.  
  4837.     """
  4838.     return TermIter(self.spellings_begin(), self.spellings_end(),
  4839.                     has_termfreq=TermIter.EAGER,
  4840.                     has_wdf=TermIter.INVALID,
  4841.                     has_positions=TermIter.INVALID)
  4842. Database.spellings = _database_gen_spellings_iter
  4843.  
  4844. # Modify Database to add a "synonyms()" method.
  4845. def _database_gen_synonyms_iter(self, term):
  4846.     """Get an iterator which returns all the synonyms for a given term.
  4847.  
  4848.     The term to return synonyms for is specified by the `term` parameter.
  4849.  
  4850.     The iterator will return string objects.
  4851.  
  4852.     """
  4853.     return TermIter(self.synonyms_begin(term),
  4854.                     self.synonyms_end(term),
  4855.                     return_strings=True)
  4856. Database.synonyms = _database_gen_synonyms_iter
  4857.  
  4858. # Modify Database to add a "synonym_keys()" method.
  4859. def _database_gen_synonym_keys_iter(self, prefix=""):
  4860.     """Get an iterator which returns all the terms which have synonyms.
  4861.  
  4862.     The iterator will return string objects.
  4863.  
  4864.     If `prefix` is non-empty, only terms with this prefix are returned.
  4865.  
  4866.     """
  4867.     return TermIter(self.synonym_keys_begin(prefix),
  4868.                     self.synonym_keys_end(prefix),
  4869.                     return_strings=True)
  4870. Database.synonym_keys = _database_gen_synonym_keys_iter
  4871.  
  4872. # Modify Database to add a "metadata_keys()" method, instead of direct access
  4873. # to metadata_keys_begin and metadata_keys_end.
  4874. def _database_gen_metadata_keys_iter(self, prefix=""):
  4875.     """Get an iterator which returns all the metadata keys.
  4876.  
  4877.     The iterator will return string objects.
  4878.  
  4879.     If `prefix` is non-empty, only metadata keys with this prefix are returned.
  4880.  
  4881.     """
  4882.     return TermIter(self._metadata_keys_begin(prefix),
  4883.                     self._metadata_keys_end(prefix),
  4884.                     return_strings=True)
  4885. Database.metadata_keys = _database_gen_metadata_keys_iter
  4886.  
  4887. # Modify Document to add an "__iter__()" method and a "termlist()" method.
  4888. def _document_gen_termlist_iter(self):
  4889.     """Get an iterator over all the terms in a document.
  4890.  
  4891.     The iterator will return TermListItem objects.
  4892.  
  4893.     Access to term frequency and position information is only available until
  4894.     the iterator has moved on.
  4895.  
  4896.     Note that term frequency information is only meaningful for a document
  4897.     retrieved from a database.  If term frequency information is requested for
  4898.     a document which was freshly created, an InvalidOperationError will be
  4899.     raised.
  4900.  
  4901.     """
  4902.     # Note: document termlist iterators may be implemented entirely in-memory
  4903.     # (in which case access to all items could be allowed eagerly), but may
  4904.     # also be implemented by returning a database termlist (for documents which
  4905.     # are stored in a database, rather than freshly created).  We choose the
  4906.     # most conservative settings, to avoid doing eager access when lazy access
  4907.     # would be more appropriate.
  4908.     return TermIter(self.termlist_begin(), self.termlist_end(),
  4909.                     has_termfreq=TermIter.LAZY,
  4910.                     has_wdf=TermIter.EAGER,
  4911.                     has_positions=TermIter.LAZY)
  4912. Document.__iter__ = _document_gen_termlist_iter
  4913. Document.termlist = _document_gen_termlist_iter
  4914.  
  4915. # Modify QueryParser to add a "stoplist()" method.
  4916. def _queryparser_gen_stoplist_iter(self):
  4917.     """Get an iterator over all the stopped terms from the previous query.
  4918.     
  4919.     This returns an iterator over all the terms which were omitted from the
  4920.     previously parsed query due to being considered to be stopwords.  Each
  4921.     instance of a word omitted from the query is represented in the returned
  4922.     list, in the order in which the
  4923.  
  4924.     The iterator will return string objects.
  4925.  
  4926.     """
  4927.     return TermIter(self.stoplist_begin(), self.stoplist_end(),
  4928.                     return_strings=True)
  4929. QueryParser.stoplist = _queryparser_gen_stoplist_iter
  4930.  
  4931. # Modify QueryParser to add an "unstemlist()" method.
  4932. def _queryparser_gen_unstemlist_iter(self, tname):
  4933.     """Get an iterator over all the unstemmed forms of a stemmed term.
  4934.     
  4935.     This returns an iterator which returns all the unstemmed words which were
  4936.     stemmed to the stemmed form specifed by `tname` when parsing the previous
  4937.     query.  Each instance of a word which stems to `tname` is returned by the
  4938.     iterator in the order in which the words appeared in the query - an
  4939.     individual unstemmed word may thus occur multiple times.
  4940.  
  4941.     The iterator will return string objects.
  4942.  
  4943.     """
  4944.     return TermIter(self.unstem_begin(tname), self.unstem_end(tname),
  4945.                     return_strings=True)
  4946. QueryParser.unstemlist = _queryparser_gen_unstemlist_iter
  4947.  
  4948. # When we set a ValueRangeProcessor into the QueryParser, keep a python
  4949. # reference so it won't be deleted. This hack can probably be removed once
  4950. # xapian bug #186 is fixed.
  4951. __queryparser_add_valuerangeprocessor_orig = QueryParser.add_valuerangeprocessor
  4952. def _queryparser_add_valuerangeprocessor(self, vrproc):
  4953.     if not hasattr(self, '_vrps'):
  4954.         self._vrps = []
  4955.     self._vrps.append(vrproc)
  4956.     return __queryparser_add_valuerangeprocessor_orig(self, vrproc)
  4957. _queryparser_add_valuerangeprocessor.__doc__ = __queryparser_add_valuerangeprocessor_orig.__doc__
  4958. QueryParser.add_valuerangeprocessor = _queryparser_add_valuerangeprocessor
  4959. del _queryparser_add_valuerangeprocessor
  4960.  
  4961. # When we set a Stopper into the QueryParser, keep a python reference so it
  4962. # won't be deleted. This hack can probably be removed once xapian bug #186 is
  4963. # fixed.
  4964. __queryparser_set_stopper_orig = QueryParser.set_stopper
  4965. def _queryparser_set_stopper(self, stopper):
  4966.     self._stopper = stopper
  4967.     return __queryparser_set_stopper_orig(self, stopper)
  4968. _queryparser_set_stopper.__doc__ = __queryparser_set_stopper_orig.__doc__
  4969. QueryParser.set_stopper = _queryparser_set_stopper
  4970. del _queryparser_set_stopper
  4971.  
  4972. # When we set a Stopper into the TermGenerator, keep a python reference so it
  4973. # won't be deleted. This hack can probably be removed once xapian bug #186 is
  4974. # fixed.
  4975. __termgenerator_set_stopper_orig = TermGenerator.set_stopper
  4976. def _termgenerator_set_stopper(self, stopper):
  4977.     self._stopper = stopper
  4978.     return __termgenerator_set_stopper_orig(self, stopper)
  4979. _termgenerator_set_stopper.__doc__ = __termgenerator_set_stopper_orig.__doc__
  4980. TermGenerator.set_stopper = _termgenerator_set_stopper
  4981. del _termgenerator_set_stopper
  4982.  
  4983. def _enquire_check_deprec_args(reverse, kwargs, methodname):
  4984.     """Check the keyword arguments to one of the enquire set_sort_* methods.
  4985.     
  4986.     """
  4987.     if reverse is not None:
  4988.         if 'ascending' in kwargs:
  4989.             raise TypeError('Only one of "reverse" and "ascending" may be specified')
  4990.         if len(kwargs) != 0:
  4991.             raise TypeError('Only keyword arguments allowed are "reverse" and "ascending"')
  4992.     else:
  4993.         if 'ascending' in kwargs:
  4994.             reverse = kwargs.get('ascending')
  4995.             del kwargs['ascending']
  4996.         else:
  4997.             reverse = True
  4998.         if len(kwargs) != 0:
  4999.             raise TypeError('Only keyword arguments allowed are "reverse" and "ascending"')
  5000.     return reverse
  5001.  
  5002. # When we set a Sorter on enquire, keep a python reference so it won't be
  5003. # deleted.  This hack can probably be removed once xapian bug #186 is fixed.
  5004. __enquire_set_sort_by_key_orig = Enquire.set_sort_by_key
  5005. def _enquire_set_sort_by_key(self, sorter, reverse=None, **kwargs):
  5006.     self._sorter = sorter
  5007.     reverse = _enquire_check_deprec_args(reverse, kwargs, "set_sort_by_key")
  5008.     return __enquire_set_sort_by_key_orig(self, sorter, reverse)
  5009. _enquire_set_sort_by_key.__doc__ = __enquire_set_sort_by_key_orig.__doc__
  5010. Enquire.set_sort_by_key = _enquire_set_sort_by_key
  5011. del _enquire_set_sort_by_key
  5012.  
  5013. __enquire_set_sort_by_key_then_relevance_orig = Enquire.set_sort_by_key_then_relevance
  5014. def _enquire_set_sort_by_key_then_relevance(self, sorter, reverse=None, **kwargs):
  5015.     self._sorter = sorter
  5016.     reverse = _enquire_check_deprec_args(reverse, kwargs, "set_sort_by_key_then_relevance")
  5017.     return __enquire_set_sort_by_key_then_relevance_orig(self, sorter, reverse)
  5018. _enquire_set_sort_by_key_then_relevance.__doc__ = __enquire_set_sort_by_key_then_relevance_orig.__doc__
  5019. Enquire.set_sort_by_key_then_relevance = _enquire_set_sort_by_key_then_relevance
  5020. del _enquire_set_sort_by_key_then_relevance
  5021.  
  5022. __enquire_set_sort_by_relevance_then_key_orig = Enquire.set_sort_by_relevance_then_key
  5023. def _enquire_set_sort_by_relevance_then_key(self, sorter, reverse=None, **kwargs):
  5024.     self._sorter = sorter
  5025.     reverse = _enquire_check_deprec_args(reverse, kwargs, "set_sort_by_relevance_then_key")
  5026.     return __enquire_set_sort_by_relevance_then_key_orig(self, sorter, reverse)
  5027. _enquire_set_sort_by_relevance_then_key.__doc__ = __enquire_set_sort_by_relevance_then_key_orig.__doc__
  5028. Enquire.set_sort_by_relevance_then_key = _enquire_set_sort_by_relevance_then_key
  5029. del _enquire_set_sort_by_relevance_then_key
  5030.  
  5031. __enquire_set_sort_by_value_orig = Enquire.set_sort_by_value
  5032. def _enquire_set_sort_by_value(self, sort_key, reverse=None, **kwargs):
  5033.     reverse = _enquire_check_deprec_args(reverse, kwargs, "set_sort_by_value")
  5034.     return __enquire_set_sort_by_value_orig(self, sort_key, reverse)
  5035. _enquire_set_sort_by_value.__doc__ = __enquire_set_sort_by_value_orig.__doc__
  5036. Enquire.set_sort_by_value = _enquire_set_sort_by_value
  5037. del _enquire_set_sort_by_value
  5038.  
  5039. __enquire_set_sort_by_relevance_then_value_orig = Enquire.set_sort_by_relevance_then_value
  5040. def _enquire_set_sort_by_relevance_then_value(self, sort_key, reverse=None, **kwargs):
  5041.     reverse = _enquire_check_deprec_args(reverse, kwargs, "set_sort_by_relevance_then_value")
  5042.     return __enquire_set_sort_by_relevance_then_value_orig(self, sort_key, reverse)
  5043. _enquire_set_sort_by_relevance_then_value.__doc__ = __enquire_set_sort_by_relevance_then_value_orig.__doc__
  5044. Enquire.set_sort_by_relevance_then_value = _enquire_set_sort_by_relevance_then_value
  5045. del _enquire_set_sort_by_relevance_then_value
  5046.  
  5047. __enquire_set_sort_by_value_then_relevance_orig = Enquire.set_sort_by_value_then_relevance
  5048. def _enquire_set_sort_by_value_then_relevance(self, sort_key, reverse=None, **kwargs):
  5049.     reverse = _enquire_check_deprec_args(reverse, kwargs, "set_sort_by_value_then_relevance")
  5050.     return __enquire_set_sort_by_value_then_relevance_orig(self, sort_key, reverse)
  5051. _enquire_set_sort_by_value_then_relevance.__doc__ = __enquire_set_sort_by_value_then_relevance_orig.__doc__
  5052. Enquire.set_sort_by_value_then_relevance = _enquire_set_sort_by_value_then_relevance
  5053. del _enquire_set_sort_by_value_then_relevance
  5054.  
  5055.  
  5056. ##########################################
  5057. # Support for iteration of posting lists #
  5058. ##########################################
  5059.  
  5060. class PostingItem(_SequenceMixIn):
  5061.     """An item returned from iteration of a posting list.
  5062.  
  5063.     The item supports access to the following attributes and properties:
  5064.  
  5065.      - `docid`: The document ID corresponding to this PostingItem.
  5066.      - `doclength`: The length of the document corresponding to this
  5067.        PostingItem.
  5068.      - `wdf`: The within document frequency of the term which the posting list
  5069.        is for in the document corresponding to this PostingItem.
  5070.      - `positer`: An iterator over the positions which the term corresponing to
  5071.        this posting list occurs at in the document corresponding to this
  5072.        PostingItem.  This is only available until the iterator which returned
  5073.        this item next moves.
  5074.  
  5075.     """
  5076.     __slots__ = ('_iter', 'docid', 'doclength', 'wdf',)
  5077.  
  5078.     def __init__(self, iter):
  5079.         self._iter = iter
  5080.         self.docid = iter._iter.get_docid()
  5081.         self.doclength = iter._iter.get_doclength()
  5082.         self.wdf = iter._iter.get_wdf()
  5083.  
  5084.         # Support for sequence API
  5085.         sequence = ['docid', 'doclength', 'wdf', 'positer']
  5086.         if not iter._has_positions:
  5087.             sequence[3] = PositionIter()
  5088.         _SequenceMixIn.__init__(self, *sequence)
  5089.  
  5090.     def _get_positer(self):
  5091.         """Get a position list iterator.
  5092.  
  5093.         The iterator will return integers representing the positions that the
  5094.         term occurs at in the document corresponding to this PostingItem.
  5095.  
  5096.         This will raise a InvalidOperationError exception if the iterator this
  5097.         item came from doesn't support position lists, or if the iterator has
  5098.         moved on since the item was returned from it.
  5099.  
  5100.         """
  5101.         if not self._iter._has_positions:
  5102.             raise InvalidOperationError("Iterator does not support position lists")
  5103.         if self._iter._iter == self._iter._end or \
  5104.            self.docid != self._iter._iter.get_docid():
  5105.             raise InvalidOperationError("Iterator has moved, and does not support random access")
  5106.         return PositionIter(self._iter._iter.positionlist_begin(),
  5107.                             self._iter._iter.positionlist_end())
  5108.     positer = property(_get_positer, doc=
  5109.     """A position iterator for the current posting (if meaningful).
  5110.  
  5111.     The iterator will return integers representing the positions that the term
  5112.     occurs at.
  5113.  
  5114.     This will raise a InvalidOperationError exception if the iterator this item
  5115.     came from doesn't support position lists, or if the iterator has moved on
  5116.     since the item was returned from it.
  5117.  
  5118.     """)
  5119.  
  5120.  
  5121. class PostingIter(object):
  5122.     """An iterator over a posting list.
  5123.  
  5124.     The iterator will return PostingItem objects, which will be evaluated
  5125.     lazily where appropriate.
  5126.  
  5127.     """
  5128.     __slots__ = ('_iter', '_end', '_has_positions', '_moved')
  5129.  
  5130.     def __init__(self, start, end, has_positions=False):
  5131.         self._iter = start
  5132.         self._end = end
  5133.         self._has_positions = has_positions
  5134.  
  5135.         # _moved is True if we've moved onto the next item.  This is needed so
  5136.         # that the iterator doesn't have to move on until just before next() is
  5137.         # called: since the iterator starts by pointing at a valid item, we
  5138.         # can't just call self._iter.next() unconditionally at the start of our
  5139.         # next() method.
  5140.         self._moved = True
  5141.  
  5142.     def __iter__(self):
  5143.         return self
  5144.  
  5145.     def next(self):
  5146.         if not self._moved:
  5147.             self._iter.next()
  5148.             self._moved = True
  5149.  
  5150.         if self._iter == self._end:
  5151.             raise StopIteration
  5152.         else:
  5153.             self._moved = False
  5154.             return PostingItem(self)
  5155.  
  5156.     def skip_to(self, docid):
  5157.         """Skip the iterator forward.
  5158.  
  5159.         The iterator is advanced to the first document with a document ID
  5160.         which is greater than or equal to the supplied document ID.
  5161.  
  5162.         If there are no such items, this will raise StopIteration.
  5163.  
  5164.         This returns the item which the iterator is moved to.  The subsequent
  5165.         item will be returned the next time that next() is called (unless
  5166.         skip_to() is called again first).
  5167.  
  5168.         """
  5169.         if self._iter != self._end:
  5170.             self._iter.skip_to(docid)
  5171.         if self._iter == self._end:
  5172.             self._moved = True
  5173.             raise StopIteration
  5174.         self._moved = False
  5175.         return PostingItem(self)
  5176.  
  5177. def _database_gen_postlist_iter(self, tname):
  5178.     """Get an iterator over the postings which are indexed by a given term.
  5179.  
  5180.     If `tname` is empty, an iterator over all the documents will be returned
  5181.     (this will contain one entry for each document, will always return a wdf of
  5182.     1, and will not allow access to a position iterator).
  5183.  
  5184.     """
  5185.     if len(tname) != 0:
  5186.         return PostingIter(self.postlist_begin(tname), self.postlist_end(tname),
  5187.                            has_positions=True)
  5188.     else:
  5189.         return PostingIter(self.postlist_begin(tname), self.postlist_end(tname))
  5190. Database.postlist = _database_gen_postlist_iter
  5191.  
  5192.  
  5193. ###########################################
  5194. # Support for iteration of position lists #
  5195. ###########################################
  5196.  
  5197. class PositionIter(object):
  5198.     """An iterator over a position list.
  5199.  
  5200.     The iterator will return integers, in ascending order.
  5201.  
  5202.     """
  5203.     def __init__(self, start = 0, end = 0):
  5204.         self.iter = start
  5205.         self.end = end
  5206.  
  5207.     def __iter__(self):
  5208.         return self
  5209.  
  5210.     def next(self):
  5211.         if self.iter==self.end:
  5212.             raise StopIteration
  5213.         else:
  5214.             r = self.iter.get_termpos()
  5215.             self.iter.next()
  5216.             return r
  5217.  
  5218. # Modify Database to add a "positionlist()" method.
  5219. def _database_gen_positionlist_iter(self, docid, tname):
  5220.     """Get an iterator over all the positions in a given document of a term.
  5221.     
  5222.     The iterator will return integers, in ascending order.
  5223.  
  5224.     """
  5225.     return PositionIter(self.positionlist_begin(docid, tname), self.positionlist_end(docid, tname))
  5226. Database.positionlist = _database_gen_positionlist_iter
  5227.  
  5228. ########################################
  5229. # Support for iteration of value lists #
  5230. ########################################
  5231.  
  5232. class ValueItem(_SequenceMixIn):
  5233.     """An item returned from iteration of the values in a document.
  5234.  
  5235.     The item supports access to the following attributes:
  5236.  
  5237.      - `num`: The number of the value.
  5238.      - `value`: The contents of the value.
  5239.  
  5240.     """
  5241.  
  5242.     __slots__ = ('num', 'value', )
  5243.  
  5244.     def __init__(self, num, value):
  5245.         self.num = num
  5246.         self.value = value
  5247.         _SequenceMixIn.__init__(self, 'num', 'value')
  5248.  
  5249. class ValueIter(object):
  5250.     """An iterator over all the values stored in a document.
  5251.  
  5252.     The iterator will return ValueItem objects, in ascending order of value number.
  5253.  
  5254.     """
  5255.     def __init__(self, start, end):
  5256.         self.iter = start
  5257.         self.end = end
  5258.  
  5259.     def __iter__(self):
  5260.         return self
  5261.  
  5262.     def next(self):
  5263.         if self.iter==self.end:
  5264.             raise StopIteration
  5265.         else:
  5266.             r = ValueItem(self.iter.get_valueno(), self.iter.get_value())
  5267.             self.iter.next()
  5268.             return r
  5269.  
  5270. # Modify Document to add a "values()" method.
  5271. def _document_gen_values_iter(self):
  5272.     """Get an iterator over all the values stored in a document.
  5273.  
  5274.     The iterator will return ValueItem objects, in ascending order of value number.
  5275.  
  5276.     """
  5277.     return ValueIter(self.values_begin(), self.values_end())
  5278. Document.values = _document_gen_values_iter
  5279.  
  5280. # Set the list of names which should be public.
  5281. # Note that this needs to happen at the end of xapian.py.
  5282. __all__ = []
  5283. for item in dir():
  5284.     if item.startswith('_') or item.endswith('_swigregister') or item.endswith('Iterator'):
  5285.         continue
  5286.     __all__.append(item)
  5287. __all__ = tuple(__all__)
  5288.  
  5289.  
  5290.  
  5291.  
  5292.